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随 着 国家 信息 化 步伐 的 加 快 和 高 等 教育 规模 的 扩大 ,社会 对 计算 机 专业 人 
才 的 需求 不 仅 体现 在 数量 的 增加 上 ,而且 体 现在 质量 要 求 的 提高 上 ,培养 具有 
研究 和 实践 能 力 的 高 层次 的 计算 机 专业 人 才 已 成 为 许多 重点 大 学 计算 机 专业 
教育 的 主要 目标 。 目 前 ,我 国共 有 16 个 国家 重点 学 科 、 名 个 博士 点 一 级 学 科 、2B8 
个 博士 点 二 级 学 科 集 中 在 教育 部 部 属 重点 大 学 ,这 些 高 校 在 计算 机 教学 和 科研 
方面 具有 一 定 优势 ,并 且 大 多 以 国际 著名 大 学 计算 机 教育 为 参照 系 ,具有 系统 
完善 的 教学 课程 体系 、 教 学 实验 体系 、 教 学 质量 保证 体系 和 人 才 培 养 评估 体系 
等 综合 体系 ,形成 了 培养 一 流 人 才 的 教学 和 科研 环境 。 

重点 大 学 计算 机 学 科 的 教学 与 科研 氛围 是 培养 一 流 计 算 机 人 才 的 基础 ， 
其 中 专业 教材 的 使 用 和 建设 则 是 这 种 氛围 的 重要 组 成 部 分 ,一 批 具有 学 科 方 
向 特色 优势 的 计算 机 专业 教材 作为 各 重点 大 学 的 重点 建设 项 目 成 果 得 到 肯 
定 。 为 了 展示 和 发 扬 各 重点 大 学 在 计算 机 专业 教育 上 的 优势 ,特别 是 专业 教 
材 建设 上 的 优势 ,同时 配合 各 重点 大 学 的 计算 机 学 科 建 设 和 专业 课程 教学 需 
要 ,在 教育 部 相关 教学 指导 委员 会 专家 的 建议 和 各 重点 大 学 的 大 力 支 持 下 ， 
清华 大 学 出 版 社 规划 并 出 版 本 系列 教材 。 本 系列 教材 的 建设 旨 在 “汇聚 学 科 
精英 .引领 学 科 建设 .培育 专业 英才 ”, 同 时 以 教材 示范 各 重点 大 学 的 优秀 教 
学 理念 .教学 方法 、 教 学 手段 和 教学 内 容 等 。 

本 系列 教材 在 规划 过 程 中 体现 了 如 下 一 些 基本 组 织 原则 和 特点 。 

1. 面向 学 科 发 展 的 前 沿 , 适 应 当前 社会 对 计算 机 专业 高 级 人 才 的 培养 需 
求 。 教 材 内 容 以 基本 理论 为 基础 ,反映 基本 理论 和 原理 的 综合 应 用 ,重视 实践 
和 应 用 环节 。 

2 反映 教学 需要 ,促进 教学 发 展 。 教 材 要 能 适应 多 样 化 的 教学 需要 ,正确 
把 握 教学 内 容 和 课程 体系 的 改革 方向 。 在 选择 教材 内 容 和 编写 体系 时 注意 体 
现 素质 教育 、 创 新 能 力 与 实践 能 力 的 培养 ,为 学 生 知 识 、 能 力 、 素 质 协调 发 展 创 
造 条 件 。 

3 实施 精品 战略 ,突出 重点 ,保证 质量 。 规 划 教材 建设 的 重点 依然 是 专业 
基础 课 和 专业 主干 课 ; 特别 注意 选择 并 安排 了 一 部 分 原来 基础 比较 好 的 优秀 教 
材 或 讲义 修订 再 版 ,逐步 形成 精品 教材 ; 提倡 并 鼓励 编写 体现 重点 大 学 计算 机 
专业 教学 内 容 和 课程 体系 改革 成 果 的 教材 。 
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4 主张 一 纲 多 本 ,合理 配套 。 专 业 基 础 课 和 专业 主干 课 教材 要 配套 ,同一 门 课程 可 以 有 多 
本 具有 不 同 内 容 特点 的 教材 。 处 理 好 教材 统一 性 与 多 样 化 的 关系 ; 基本 教材 与 辅助 教材 以 及 
教学 参考 书 的 关系 ; 文字 教材 与 软件 教材 的 关系 ,实现 教材 系列 资源 配套 。 

5 依靠 专家 ,择优 落实 。 在 制订 教材 规划 时 要 依靠 各 课程 专家 在 调查 研究 本 课程 教材 建 
设 现状 的 基础 上 提出 规划 选 题 。 在 落实 主编 人 选 时 ,要 引入 竞争 机 制 , 通 过 申报 .评审 确定 主 
编 。 书 稿 完成 后 要 认真 实行 审 稿 程序 ,确保 出 书 质量 。 

繁荣 教材 出 版 事业 ,提高 教材 质量 的 关键 是 教师 。 建 立 一 支 高 水 平 的 以 老 带 新 的 教材 编 
写 队 伍 才能 保证 教材 的 编写 质量 ,希望 有 志 于 教材 建设 的 教师 能 够 加 入 到 我 们 的 编写 队伍 
中 来 。 


教材 编 委 会 
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ASP NET 4 5 是 Miarosoft 公司 推出 的 建立 动态 wb 应 用 程序 的 开发 平台 , 它 为 开 
发 人 员 提 供 了 完整 的 可 视 化 开发 环境 ,具有 使 用 方便 、 灵 活 、 性 能 好 ,安全 性 高 、 
完整 性 强 及 面向 对 象 等 特性 ,是 目前 主流 的 网 络 编程 工具 之 一 。 

本 书 以 C# 为 编程 工具 、SQL Server 为 数据 库 平台 介绍 动态 网 站 的 开发 方法 。 

全 书 分 为 18 章 ,第 1 章 为 AP. ET 概述 ; 第 2 章 为 Kp. ET 网 站 结构 ; 第 3 章 
为 使 用 Kp ET 进行 HM5 和 C53 设计 ; 第 4 章 为 C# 语言 基础 ; 第 5 章 为 AP NET 
的 常用 对 象 ; 第 6 章 为 上 b 标 准 服务 器 控件 ; 第 7 章 为 AP NET 验 证 控件 ; 第 8 章 
为 用 户 控件 ; 第 9 章 为 主题 和 母 版 页 ; 第 10 章 为 站 点 导航 控件 ; 第 11 章 为 生 
NET A 以 控件 ; 第 12 章 为 A0 NET 数据 库 访问 技术 ; 第 13 章 为 语言 集成 查询 一 一 
UN0; 第 14 章 为 Wb 系统 的 多 层 结构 ; 第 15 章 为 AP. NET Web 服 务 ; 第 16 章 为 配置 
ASP ET 应 用 程序 ; 第 17 章 为 成 员 资格 和 角色 管理 ; 第 18 章 为 学 生成 绩 管理 网 
站 设计 ,讨论 中 小 型 网 站 的 开发 过 程 ,具有 综合 性 。 

书 中 各 章 提供 了 一 定数 目的 练习 题 和 上 机 实验 题 供 读者 选用 ,练习 题 主要 
考查 学 生 对 基本 知识 点 的 理解 程度 ,学 生 通过 温习 便 可 完成 ,除了 个 别 题目 外 
没有 提供 参考 答案 ; 上 机 实验 题 是 对 能 力 的 考查 ,要 求学 生 具 有 一 定 的 设计 能 
力 。 附 录 A 给 出 了 大 部 分 上 机 实验 题 设计 参考 答案 ,附录 B 给 出 了 6 个 综合 上 
机 实验 题 ,附录 C 给 出 了 使 用 学 生成 绩 管理 系统 的 过 程 。 

本 书 的 读者 对 象 仅仅 需要 具备 基本 的 HIM 网 页 设计 和 程序 设计 知识 。 

本 书 是 “ASP ET 动态 网 站 设计 ”课程 组 全 体 教师 长 期 教学 经 验 和 教学 方法 
的 总 结 ,是 学 习 和 吸收 国内 外 相关 主流 教材 和 著作 的 成 果 , 全 书 具有 如 下 特色 。 

(1) 知识 全 面 、 内 容 翔实 : 在 讲授 上 力求 翔实 和 全 面 ,细致 地 解析 每 个 知识 
点 和 各 知识 点 的 联系 。 

(2 条 理 清晰 、 讲 解 透彻 : 从 介绍 AP NET 的 基本 概念 出 发 ,由 简单 到 复杂 ， 
循序 渐进 地 介绍 AP ET 动态 网 站 开发 方法 。 

(3 实例 丰富 、 实 用 性 强 : 列举 了 大 量 的 应 用 示例 ,读者 通过 上 机 模仿 可 以 
极 大 地 提高 进行 AP NET 动 态 网 站 开发 的 能 力 。 

(4 为 了 方便 教师 教学 和 学 生 学 习 , 本 书 提供 了 全 面 .丰富 的 教学 资源 , 配 
套 的 教学 资源 包括 如 下 内 容 。 

@ PPT: 供 任课 教师 在 教学 中 使 用 。 
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@ 源 程序 代码 : 存放 在 AS ET 文件 夹 中 ,每 章 对 应 一 个 子 文件 夹 ,例如 ,\d2 文 件 夹 包含 
第 2 章 的 所 有 示例 代码 ,“\ 学 生成 绩 管理 系统 ”文件 夹 包含 第 18 章 的 学 生成 绩 管理 系统 的 全 
部 代码 。 

@ 上 机 实验 题 源 程序 代码 : 存放 在 各 章 对 应 的 文件 夹 中 ,例如 ,\d2 文 件 夹 中 的 Epement2 
便 是 上 机 实验 题 2 的 网 页 。 
上 述 所 有 教学 资源 均 可 从 清华 大 学 出 版 社 网 站 免费 下 载 。 欢 迎 使 用 本 书 的 教师 和 读者 与 
编者 联系 ,联系 邮箱 为 Tichl9M@126 com。 由 于 编者 水 平 所 限 , 书 中 难免 有 不 当 和 错误 之 处 ,元 请 
广大 读者 指正 。 

本 书 的 编写 得 到 湖北 省 教改 项 目 、 武 汉 大 学 计算 机 学 院 、 解 放 军 理工 大 学 以 及 清华 大 学 出 
版 社 的 大 力 支持 ,在 此 一 并 表示 京 心 的 感谢 。 


编 者 
2015 年 10 月 
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ASP.NET 概述 第 1 章 


ASP.NET 是 一 种 动态 网 页 开发 技术 , 它 使 用 Visual Studio 集成 开发 环境 
中 的 兼容 语言 作为 编程 语言 来 开发 Web 应 用 程序 。 本 章 介 绍 与 ASP. NET 相 
关 的 一 些 基 本 概念 和 网 站 开发 技术 ,为 后 续 章 节 的 学 习 打下 基础 。 

本 章 学 习 要 点 : 

回 掌 握 WWW 的 基本 概念 。 

回 掌握 静态 网 页 和 动态 网 页 的 区 别 。 

回 了 解 Web 开发 的 相关 技术 。 

回 掌 握 ASP.NET 的 特点 和 ASP.NET 引擎 的 工作 原理 。 

回 了 解 .NET Framework 的 体系 结构 。 

回 掌 握 Visual Studio 开发 Web 应 用 程序 的 集成 开发 环境 。 

回 掌 握 使 用 Visual Studio 开发 网 站 的 过 程 。 


1.1 WWW 的 基础 知识 


1.1.1 WWW 简介 
1. 计算 机 网 络 
计算 机 网 络 是 指 将 地 理 位 置 不 同 的 具有 独立 功能 的 多 台 计 算 机 及 其 外 部 
设备 通过 通信 线路 连接 起 来 ,在 网 络 操作 系统 .网 络 管理 软件 及 网 络 通信 协议 
的 管理 和 协调 下 实现 资源 共享 和 信息 传递 的 计算 机 系统 。 
计算 机 网 络 类 型 的 划分 标准 多 种 多 样 , 其 中 从 地 理 范围 划分 是 一 种 被 人 们 
公认 的 通用 网 络 划分 标准 , 按 这 种 标准 可 以 把 各 种 计算 机 网 络 划分 为 以 下 
类 型 。 
。 局 域 网 (Local Area Network,LAN): 指 在 某 一 区 域内 由 多 台 计 算 机 互 
连 而 成 的 计算 机 组 ,一 般 是 在 方圆 几 千 米 以 内 。 局 域 网 可 以 实现 文件 
管理 .应 用 软件 共享 .打印 机 共享 `. 工 作 组 内 的 日 程 安排 .电子 邮件 和 传 
真 通 信服 务 等 功能 。 局 域 网 是 封闭 型 的 .可 以 由 办 公 室 内 的 两 台 计 算 
机 组 成 :也 可 以 由 一 个 公司 内 的 上 千 台 计算 机 组 成 。 
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。 城 域 网 (Metropolitan Area Network,MAN) : 指 在 一 个 城市 范围 内 所 建立 的 计算 机 通 
信和 网 , 属 宽带 局 域 网 。 它 的 一 个 重要 用 途 是 用 作 骨 干 网 ,通过 它 将 位 于 同一 城市 内 不 
同 地 点 的 主机 .数据库 以 及 LAN 等 互相 连接 起 来 。 

。 广域网 (Wide Area Network, WAN): 也 称 远程 网 ,通常 跨 很 大 的 物理 范围 ,所 覆盖 的 
范围 从 几 十 千 米 到 几 千 千 米 , 它 能 连接 多 个 城市 或 国家 ,或 横 跨 几 个 洲 , 并 能 提供 远 距 
离 通信 ,形成 国际 性 的 远程 网 络 。 

要 想 让 两 台 计 算 机 进行 通信 ,必须 使 它们 采用 相同 的 信息 交换 规则 。 通 常 把 在 计算 机 网 
络 中 用 于 规定 信息 的 格式 以 及 如 何 发 送 和 接收 信息 的 一 套 规则 称 为 网 络 协议 或 通信 协议 ,如 
TCP/IP 协议 。 

迄今 为 止 ,计算 机 网 络 经 过 了 4 个 阶段 的 发 展 , 即 远程 终端 联机 阶段 .计算 机 网 络 阶段 . 计 
算 机 网 络 互联 阶段 和 国际 互联 网 与 信息 高 速 公 路 阶段 。 

2. WWW ,互联 网 和 因特网 

WWW 是 环球 信息 网 (World Wide Web) 的 缩写 (也 为 Web、W3 等 ), 中 文 名字 为 万 维 
网 、 环 球 网 等 。 它 起 源 于 1989 年 3 月 ,是 由 欧洲 粒子 物理 实验 室 研究 发 展 起 来 的 主 从 结构 
分 布 式 超 媒体 系统 ,最 初 的 开发 设计 目的 是 为 该 实验 室 的 物理 学 家 们 提供 一 种 共享 信息 的 
工具 。 


1980 年 欧洲 粒子 物理 实验 室 的 蒂 姆 。 伯 纳 斯 - 李 构建 了 ENQUIRE 项 目 。 
1989 年 3 月 ,他 撰写 了 《关于 信息 化 管理 的 建议 ) 一 文 , 文中 提 及 
ENQUIRE 并 描述 了 一 个 更 加 精巧 的 管理 模型 。1990 年 11 月 12 日 ,他 和 
罗伯特 。 卡 里 奥 合 作 提出 了 一 个 更 加 正式 的 关于 WWW 的 建议 。1990 年 
11 月 13 日 ,他 在 一 台 NeXT 工作 站 上 编写 了 第 一 个 网 页 以 实现 他 文中 的 
想法 ,并 制作 了 一 个 网 络 工作 所 必需 的 所 有 工具 ,包括 第 一 个 WWW 浏览 
器 (同时 也 是 编辑 器 ) 和 第 一 个 网 页 服务 器 。1991 年 8 月 6 日 ,他 在 alt. 
hypertext 新 闻 组 上 贴 了 关于 WWW 项 目 简介 的 文章 ,这 一 天 也 标志 着 因 
蒂 姆 " 伯 纳 斯 - 李 特 网 上 万 维 网 公共 服务 的 首次 诞生 。 


要 理解 WWW, 用 户 必须 了 解 互联 网 (internet) 和 因特网 (Internet) 这 两 个 十 分 容易 混淆 
的 名 字 。《 现 代 汉 语词 典 )》(2002 年 增补 本 ) 将 互联 网 定义 为 " 指 由 若干 电子 机 网 络 相互 连接 而 
成 的 网 络 ”, 将 因特网 定义 为 "全球 最 大 的 一 个 电子 计算 机 互联 网 ,是 由 美国 的 ARPA 网 发 展 
演变 而 来 的 ”因特网 的 英文 首 字母 用 大 写 表示 。 

也 就 是 说 ,互联 网 是 网 络 与 网 络 之 间 串 连 成 的 庞大 网 络 , 这 些 网 络 以 一 组 通用 的 协议 相 
连 ,形成 逻辑 上 的 单一 巨大 的 国际 网 络 。 因 特 网 和 其 他 类 似 的 由 计算 机 相互 连接 而 成 的 大 型 
网 络 系统 都 可 算是 互联 网 ,因特网 只 是 互联 网 中 最 大 的 一 个 。 

而 WWW 是 无 数 个 网 络 站 点 和 网 页 的 集合 ,它们 在 一 起 构成 了 因特网 最 主要 的 部 分 。 实 
际 上 ,WWW 是 多 媒体 的 集合 ,是 由 超 链接 连接 而 成 的 。 人 们 通常 通过 网 络 浏览 器 上 网 观看 
到 的 就 是 WWW 的 内 容 。 所 以 ,WWW 并 不 等 同 于 因特网 , 它 只 是 因特网 所 能 提供 的 服务 之 
一 ,是 靠 因特网 运行 的 一 项 服务 。 或 者 说 ,因特网 指 的 是 一 个 硬件 的 网 络 ,而 WWW 更 倾向 于 
一 种 浏览 网 页 的 功能 。 

另外 有 一 个 名 字 是 Intranet, 称 为 企业 内 部 网 ,是 因特网 技术 在 企业 内 部 的 应 用 。 它 实际 
上 是 采用 因特网 技术 建立 的 企业 内 部 网 络 ,在 一 个 企业 或 组 织 的 内 部 并 为 其 成 员 提 供 信息 的 
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共享 和 交流 等 服务 ,如 文件 传输 .电子 邮件 等 。Intranet 在 内 部 网 络 上 采用 TCP/IP 作为 通 
信 协 议 ,利用 因特网 的 WWW 模型 作为 标准 信息 平台 ,同时 建立 防火 墙 把 内 部 网 和 因特网 
分 开 。 当 然 ,Intranet 并 非 一 定 要 和 因特网 连接 在 一 起 , 它 完 全 可 以 自 成 一 体 作 为 一 个 独立 
的 网 络 。 

万 维 网 联盟 (World Wide Web Consortium,W3C) 又 称 W3C 理事 会 , 它 于 1994 年 10 月 在 
麻 省 理工 学 院 CMIT) 计 算 机 科学 实验 室 成 立 。 万 维 网 联盟 的 创建 者 是 万 维 网 的 发 明 者 带 姆 . 伯 
纳 斯 - 李 。 


1.1.2 WWW 的 特点 和 系统 结构 

1. WWW 的 特点 

WWW 的 特点 如 下 : 

(1) WWW 是 图 形 化 和 易于 导航 的 。 

WWW 可 以 提供 将 图 形 、 音 频 、 视 频 信息 集合 于 一 体 的 特性 。 另 外 ,WWW 使 用 一 种 超 文 
本 (hypertext) 链 接 技 术 。 超 文本 可 以 是 WWW 网 页 上 的 任意 一 个 元 素 , 由 它 指 向 因特网 上 的 
其 他 WWW 元 素 , 所 以 ,WWW 是 非常 易于 导航 的 ,浏览 用 户 可 以 在 各 站 点 各 网 页 之 间 进 行 方 
便 的 浏览 。 

(2) WWW 与 平台 无 关 。 

无 论 系统 平台 是 什么 ,用 户 都 可 以 通过 因特网 访问 WWW。 浏览 WWW 对 系统 平台 没有 
什么 限制 ,无 论 从 Windows 平台 或 UNIX 平台 等 都 可 以 访问 WwWW。 对 WWW 的 访问 是 通 
过 一 种 被 称 为 浏览 器 的 软件 实现 的 ,例如 Netscape 的 Navigator、Microsoft 的 Explorer 等 。 

(3) WWW 是 分 布 式 的 。 

大 量 的 图 形 .音频 和 视频 信息 会 占用 相当 大 的 磁盘 空间 ,我 们 甚至 无 法 预知 信息 的 多 少 。 
对 于 WWW 没有 必要 把 所 有 信息 都 放 在 一 起 ,信息 可 以 放 在 不 同 的 站 点 上 ,只 需要 在 浏览 器 
中 指明 这 个 站 点 就 可 以 了 。 使 在 物理 上 并 不 一 定 在 一 个 站 点 的 信息 在 逻辑 上 一 体 化 ,从 用 户 
来 看 这 些 信息 是 一 体 的 。 

(4) WWW 是 动态 的 。 

由 于 各 WWW 站 点 包含 站 点 本 身 的 信息 ,信息 的 提供 者 可 以 经 常 对 站 点 上 的 信息 进行 更 
新 ,所 以 WWW 站 点 上 的 信息 是 动态 的 。 

2. WWW 网 页 .网 页 文件 和 网 站 

WWW 网 页 (web page) 也 称 为 页 面 , 是 指 因特网 上 按照 HTML( 超 文本 标记 语言 ) 格 式 组 
织 起 来 的 文件 ,在 通过 因特网 进行 信息 查询 时 以 信息 页 面 的 形式 出 现 , 它 可 包括 图 形 、 文 字 、 声 
音 和 视频 等 信息 。 网 页 是 网 站 的 基本 信息 单位 .是 WWW 的 基本 文档 , 它 由 文字 、 图 片 、 动 画 、 
声音 等 多 种 媒体 信息 以 及 链接 组 成 ,是 用 HTML 编写 的 ,通过 链接 实现 与 其 他 网 页 或 网 站 的 
关联 和 跳 转 。 

网 页 文件 是 用 HTML( 标 准 通用 标记 语言 下 的 一 个 应 用 ) 编 写 的 可 在 WWW 上 传输 能 被 
浏览 器 识别 显示 的 文本 文件 ,其 扩展 名 是 htm 和 html 等 。 

网 站 通常 由 众多 不 同 内 容 的 网 页 构成 ,具有 独立 域名 ,网 页 的 内 容 可 体现 网 站 的 全 部 功 
能 。 通 常 把 进入 网 站 首先 看 到 的 网 页 称 为 首页 或 主页 (homepage) ,新 浪 、 网 易 、 搜 狐 是 国内 比 
较 知 名 的 大 型 门户 网 站 。 

3. WWW 的 系统 结构 

WWW 的 系统 结构 采用 的 是 客户 机 /服务 器 结构 模式 ,如 图 1.1 所 示 。WWW 可 以 让 客 
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户 机 (常用 浏览 器 ) 通 过 因特网 访问 服务 器 上 的 网 二 
页 。 在 这 个 结构 中 ,所 有 资源 由 一 个 全 局 “统一 资 仿 2 目 里 
源 标识 符 ”(URL) 来 标识 ,这 些 资源 通过 超 文本 传 机 a 
输 协议 (HTTP) 传 送 给 用 户 。 


1.1.3 WWW 的 工作 原理 

1. 服务 器 端 和 客户 机 端 

要 了 解 WWW 的 工作 原理 ,首先 要 了 解 什 么 是 服务 器 端 ( 或 服务 端 ) 和 客户 机 端 ( 或 客 
户 端 ) 。 

通常 提供 服务 的 一 方 称 为 服务 端 ,接受 服务 的 一 方 称 为 客户 端 。 例 如 , 当 读 者 在 浏览 新 浪 
网 站 主页 时 ,新 浪 网 站 主页 所 在 的 服务 器 称 为 服务 端 ,而 读者 自己 的 计算 机 称 为 客户 端 。 

只 要 在 计算 机 上 安装 有 接受 服务 的 软件 ,这 台 计 算 机 就 变 成 一 台 服务 器 。 例 如 ,在 一 台 计 
算 机 上 安装 有 数据 库 服 务 器 组 件 ( 如 SQL Server) , 它 就 是 一 台数 据 库 服务 器 。Web 服务 器 
(或 WWW 服务 器 ) 是 指 具 有 允许 它们 接受 和 响应 来 自 客户 端 计算 机 的 请 求 的 特定 软件 的 计 
算 机 ,Web 服务 器 允许 用 户 通 过 Internet/Intranet 共享 信息 。 

在 一 台 计 算 机 上 安装 客户 端 软 件 ,这 台 计 算 机 就 变 成 一 台 客 户 机 。 在 因特网 中 客户 端 软 
件 主 要 有 浏览 器 ,如 IE 浏览 器 等 。 

这 里 的 服务 器 和 客户 机 并 不 是 从 硬件 上 划分 的 ,如 果 一 台 计 算 机 上 既 安 装 服务 器 软件 又 
安装 有 客户 机 软件 , 则 它 既 是 服务 器 又 是 客户 机 ,也 就 是 说 它 既 可 以 作为 服务 端 又 可 以 作为 客 
户 端 。 如 果 此 时 本 机 的 客户 端 访问 本 机 的 服务 端 , 相 对 该 客户 端 而 言 ,该 服务 端 称 为 本 机 服 
务 端 。 

2. 超 文 本 传输 协议 (HTTP) 

可 以 说 ,因特网 能 够 迅速 扩展 的 原因 是 WWW 的 迅速 发 展 ,而 WWW 不 断 成 功 的 最 主要 
原因 是 超 文本 传输 协议 的 高 效 性 。HTTP 是 一 种 以 TCP/IP 通信 协议 为 基础 的 应 用 协议 , 它 
提供 了 在 WWW 服务 器 和 客户 端 浏览 器 之 间 传 输 信息 的 一 种 机 制 。 也 就 是 说 ,HTTP 负责 规 
定 客户 端 浏览 器 和 服务 器 是 怎样 互相 交流 的 。 

(1) HTTP 协议 的 特点 

HTTP 协议 的 主要 特点 可 概括 如 下 : 

。 支持 客户 机 /服务 器 模式 。 

。 简单 快速 : 客户 机 向 服务 器 请 求 服务 时 只 需 传送 请 求 方法 和 路 径 。 由 于 HTTP 协议 

简单 ,使 得 HTTP 服务 器 的 程序 规模 小 ,因而 通信 速度 很 快 。 
。 灵活 : HTTP 允许 传输 任意 类 型 的 数据 对 象 。 
。 无 连接 : 无 连接 的 含义 是 限制 每 次 连接 只 处 理 一 个 请 求 。 服 务 器 处 理 完 客户 的 请 求 
并 收 到 客户 的 应 答 后 , 即 断 开 连 接 。 采 用 这 种 方式 可 以 节省 传输 时 间 。 

。 无 状态 : HTTP 协议 是 无 状态 协议 。 无 状态 是 指 协议 对 于 事务 处 理 没有 记忆 能 力 。 
缺少 状态 意味 着 如 果 后 续 处 理 需要 前 面 的 信息 , 则 它 必须 重 传 ,这 样 可 能 导致 每 次 连 
接 传送 的 数据 量 增 大 。 另 一 方面 ,在 服务 器 不 需要 先前 信息 时 它 的 应 答 较 快 。 

(2) URL 

因特网 上 的 每 一 个 网 页 都 具有 一 个 唯一 的 名 称 标识 .通常 称 之 为 URL( 统 一 资源 定位 符 ) 
地 址 ,这 种 地 址 可 以 是 本 地 磁盘 ,也 可 以 是 局 域 网 上 的 某 一 台 计 算 机 ,更 多 的 是 因特网 上 的 网 


HTTP 响 应 


图 1.1 WWW 的 客户 机 /服务 器 结构 模式 
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站 。 简 单 地 说 ,URL 就 是 WWW 地 址 ,俗称 “网址 ”。 其 基本 格式 如 下 : 


De! 


protocol:// hostname[ :port] /path/ 


对 各 部 分 说 明 如 下 。 
。 protocol: 指定 使 用 的 传输 协议 ,通常 为 HTTP。 
。 hostname( 主 机 名 ) : 指 存放 资源 的 服务 器 的 域名 系统 (DNS) 主 机 名 或 IP 地 址 。 
。 port( 端 口号 ) : 整数 ,可 选 ,省 略 时 使 用 默认 端口 。 各 种 传输 协议 都 有 默认 的 端口 号 ， 
如 HTTP 的 默认 端口 为 80。 
。 path( 路 径 ) : 由 零 或 多 个 “/” 符 号 隔 开 的 字符 串 ,一 般 用 来 表示 主机 上 的 一 个 目录 或 文 
件 名 (如 果 省 略 目 录 , 服 务 器 在 网 站 主 目录 查找 文件 ; 如 果 省 略 文件 名 ,服务 器 查找 名 
为 index. html index. htm、default. html 或 default. htm 的 文件 ) 。 
例如 : 
http://localhost:50922/WebForml.aspx. 
Ne ee fd 


HTTP 协 议 “本 地 服务 器 页 文件 
协议 喧嚣 汶 50922 网 页 文件 


http://www.whu.edu.cn/znbm.htm 
i sh 

HTTP 协 议 武汉 大 学 而 立 作 
网 站 网 页 文件 


URL 提供 了 位 于 本 地 WWW 服务 器 或 远程 WWW 服务 器 上 的 信息 ,通过 使 用 HTTP 管 


这 些 信 息 ,这 样 用 户 就 可 以 在 WWW 上 创建 对 URL 的 引用 了 。 


(3) HTTP 的 工作 原理 
WWW 使 用 HTTP 协议 传输 各 种 超 文 本 网 页 和 数据 ,HTTP 协议 的 会 话 过 程 包括 如 下 4 


个 步 又。 


@ 建立 连接 : 客户 端的 浏览 器 向 服务 端 发 出 建立 连接 的 请 求 ,服务 端 给 出 响应 就 可 以 建 


立 连接 了 。 


@ 发 送 请 求 : 客户 端 按照 协议 的 要 求 通过 连接 向 服务 端 发 送 自己 的 请 求 。 客 户 端 通常 


采用 HTTP URL 向 服务 器 端 发 出 访问 请 求 。 


@ 给 出 应 答 : 服务 端 按照 客户 端的 要 求 给 出 应 答 ,把 结果 CHTML 文件 ) 返 回 给 客户 端 。 


也 就 是 说 ,服务 端 将 选中 的 HTML 文档 通过 该 次 连接 传输 到 客户 端 ， 并 将 其 在 浏览 器 中 显示 
出 来 。 


器 将 会 


息 


心 。 


@ 关闭 连接 : 客户 端 接 到 应 答 后 关闭 连接 。 也 就 是 说 ,HTML 文档 传 到 客户 端 后 ,服务 
立即 自动 终止 这 个 TCP/IP 连接 。 

注意 : 在 向 客户 端 发 送 所 请 求 文件 的 同时 ,服务 器 并 没有 存储 关于 该 客户 的 任何 状态 信 
即便 某 个 客户 端 在 几 秒 钟 内 再 次 请 求 同 一 个 对 象 , 服 务 器 也 不 会 响应 说 “自己 刚刚 给 它 发 


送 了 这 个 对 象 ”。 


例如 , 某 客户 端 发 送 请 求 的 URL 为 ， 


http://www. Website. com/somepath/index. html 


假设 相应 的 index. html 网 页 由 一 个 基本 HTML 文件 和 5 个 JPEG 图 像 文件 构成 ,而 且 


所 有 这 些 对 象 都 存放 在 同一 台 服 务 器 主机 中 , 则 完整 的 会 话 过 程 如 下 : 
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@ 客户 机 初始 化 一 个 与 服务 器 主机 www. Website. com 中 的 服务 器 的 TCP 连接 。 服 务 
器 使 用 默认 端口 号 80 监听 来 自 客户 机 的 连接 建立 请 求 。 

@ 客户 机 经 由 与 TCP 连接 相关 联 的 本 地 套 接 字 发 出 一 个 HTTP 请 求 消息 。 这 个 消息 
中 包含 路 径 名 /somepath/index. html”。 

@ 服务 器 经 由 与 TCP 连接 相关 联 的 本 地 套 接 字 接 收 这 个 请 求 消息 ,再 从 服务 器 主机 的 
内 存 或 硬盘 中 取出 对 象 /somepath/index. html, 经 由 同一 个 套 接 字 发 出 包含 该 对 象 的 响应 
消息 。 

@ 服务 器 告知 TCP 关闭 这 个 TCP 连接 (不 过 TCP 要 到 客户 机 收 到 刚才 这 个 响应 消息 
之 后 才 会 真正 终止 这 个 连接 )。 

@ 客户 机 经 由 同一 个 套 接 字 接收 这 个 响应 消息 ,TCP 连接 随后 终止 。 该 消息 表明 所 封 
装 的 对 象 是 一 个 HTML 文件 。 客 户 机 从 中 取出 这 个 文件 ,加 以 分 析 后 发 现 其 中 有 5 个 JPEG 
对 象 的 引用 。 

@ 对 每 一 个 引用 到 的 JPEG 对 象 重 复 步 骤 O 一 四 。 

3. 其 他 传输 协议 

(1) HTTPS( 超 文本 传输 安全 协议 ) 

HTTP 将 用 户 的 数据 (包括 用 户 名 和 密码 ) 都 以 明文 传送 ,具有 安全 隐患 ,容易 被 他 人 窃 
听 , 对 于 具有 敏感 数据 的 传送 ,可 以 使 用 具有 保密 功能 的 HTTPS 协议 。 

HTTPS 的 主要 思想 是 在 不 安全 的 网 络 上 创建 一 个 安全 信道 ,并 可 在 使 用 适当 的 加 密 包 
和 服务 器 证 书 可 被 验证 且 可 被 信任 时 对 窍 听 和 中 间 人 攻击 提供 合理 的 防护 。 

一 个 到 某 网 站 的 HTTPS 连接 可 被 信任 , 当 且 仅 当 用 户 相 信和 其 浏览 器 正确 实现 了 
HTTPS 且 安 装 了 正确 的 证 书 颁发 机 构 、 用 户 相信 证 书 颁发 机 构 仅 信任 合法 的 网 站 、 被 访问 的 
网 站 提供 了 一 个 有 效 的 证 书 和 该 证 书 正确 地 验证 了 被 访问 的 网 站 等 。 

(2) FTP( 文 件 传 输 协议 ) 

FTP 是 因特网 中 用 于 访问 远程 机 器 的 另 一 个 协议 , 它 使 用 户 可 以 在 本 地 机 和 远程 机 之 间 
进行 有 关 文件 的 操作 。FTP 协议 允许 传输 任意 文件 并 且 允 许 文 件 具 有 所 有 权 与 访问 权限 。 
也 就 是 说 ,通过 FTP 协议 可 以 与 因特网 上 的 FTP 服务 器 进行 文件 的 上 传 或 下 载 等 操作 。 

FTP 实现 的 目标 是 促进 文件 的 共享 (计算 机 程序 或 数据 ) .鼓励 间接 或 者 隐 式 地 使 用 远程 
计算 机 、 向 用 户 屏蔽 不 同 主机 中 各 种 文件 存储 系统 的 细节 及 提供 可 靠 和 高 效 的 传输 数据 。 

与 其 他 因特网 应 用 一 样 ,FTP 也 采用 了 客户 机 /服务 器 模式 , 它 包含 客户 机 FTP 和 服务 
器 FTP, 客 户 机 FTP 启动 传送 过 程 ,而 服务 器 FTP 对 其 做 出 应 答 。 在 因特网 上 有 一 些 网 站 ， 
它们 依照 FTP 协议 提供 服务 ,让 网 友 们 进行 文件 的 存 取 ,这 些 网 站 就 是 FTP 服务 器 。 网 上 的 
用 户 要 连 上 FTP 服务 器 ,就 要 用 到 FTP 的 客户 端 软 件 。 通 常 Windows 都 有 ftp 命令 ,这 实 
际 上 就 是 一 个 命令 行 的 FTP 客户 端 程序 ,另外 常用 的 FTP 客户 端 程序 还 有 CuteFTP、 
LeapFTP、FlashFXP 等 。 


1.1.4 静态 网 页 和 动态 网 页 


在 因特网 中 最 常见 的 就 是 WWW 网 页 ,一 般 来 说 ,出 现在 浏览 器 中 的 Web 网 页 不 外 乎 有 
两 种 , 即 静态 网 页 和 动态 网 页 。 

1. 静态 网 页 

所 谓 静 态 网 页 就 是 指 那些 不 能 够 接收 用 户 输入 信息 的 Web 网 页 ,其 内 容 是 静态 的 ,唯一 
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的 响应 就 是 接收 鼠标 点 击 超 链接 后 显示 所 连接 的 网 页 。 当 用 户 用 鼠标 点 击 其 中 一 个 超 链 接 
后 ,就 会 在 浏览 器 中 显示 所 连接 的 网 页 信息 。 
静态 网 页 采用 HTML 标记 语言 编写 ,静态 网 页 文件 通常 采用 html 或 htm 等 扩展 名 。 
例如 ,采用 Windows 中 的 记事 本 编写 以 下 静态 网 页 代码 并 存储 在 spage. html 文件 中 : 


<html> 
<head> 
<title> 一 个 静态 网 页 </title> 
</head> 
<body> 
< center > 
< font face = "黑体 "><h2 > ASP .NET 程序 设计 课程 </h2 ></font > 
< font face = "宋体 "><h3 > 欢迎 光临 </h3 ></font > 
</center> 
</body> 
</html > 
双击 该 文件 ,在 下 浏览 器 中 显示 的 结果 如 图 1.2 所 示 。 在 浏览 器 中 右 击 ,在 出 现 的 快捷 
菜单 中 选择 “查看 源 ” 命 令 ,显示 的 源 代码 与 上 述 代码 相同 。 
从 中 可 以 看 到 ,静态 网 页 中 没有 程序 代码 ,只 有 HTML 标记 。 
静态 网 页 的 工作 过 程 如 图 1. 3 所 示 , 其 基本 步骤 如 下 : 
Q@ 用 户 通过 客户 机 浏览 器 输入 网 址 并 回 车 发 出 WWW 请 求 。 
@ 服务 器 收 到 静态 网 页 请 求 。 
@ 服务 器 从 硬盘 的 指定 位 置 查找 相应 的 HTML 文件 。 
@ 将 在 硬盘 中 找到 的 HTML 文件 返回 给 服务 器 。 
@ 服务 器 向 客户 机 返回 该 请 求 的 文件 。 
@ 客户 机 浏览 器 收 到 请 求 的 文件 ,并 解析 这 些 HTML 代码 将 它 显示 出 来 。 


(DA 司 DAsPNET\chl\spat P - C| 全 一 各 杰 风 页 
ASP. NET 程 序 设 计 课程 | 图 
一，Intemet 过” 二 本 | 二 二 | 硬盘 
欢迎 光临 国光 四 


客户 机 服务 器 
图 1.2 一 个 静态 网 页 在 IE 浏览 器 中 显示 的 结果 图 1.3 静态 网 页 的 工作 过 程 


从 中 可 以 看 到 ,WWW 服务 器 的 主要 功能 是 找到 用 户 要 访问 的 网 页 文件 ,不 做 任何 改动 
直接 传 给 客户 端 。 也 就 是 说 ,静态 网 页 是 实 实在 在 保存 在 服务 器 上 的 文件 ,每 个 网 页 都 是 一 个 
独立 的 文件 。 由 于 静态 网 页 没有 数据 库 的 支持 ,内 容 相 对 稳定 ,因此 容易 被 Web 服务 器 查找 ， 
访问 效率 较 高 。 

需要 指出 的 是 ,静态 网 页 中 可 以 包含 客户 端 脚 本 ,常见 的 客户 端 脚本 语言 有 JavaScript 或 
VBScript 等 。 客 户 端 脚本 在 一 个 特定 的 网 页 中 改变 界面 以 及 行为 或 者 响应 鼠标 或 键盘 操作 ， 
如 滚动 字幕 。 在 这 种 情况 下 ,客户 端 会 发 生动 态 行为 ,但 客户 端 生成 的 内 容 都 在 用 户 的 本 地 计 
算 机 系统 中 。 也 就 是 说 ,这 类 网 页 的 动态 行为 都 是 在 客户 端 进行 的 ,是 在 客户 端 “ 动 ”, 而 网 页 
本 身 是 静态 生成 的 ,所 以 仍 将 这 类 网 页 归 入 静态 网 页 。 
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2. 动态 网 页 

所 谓 动态 网 页 就 是 执行 时 用 户 可 以 输入 所 允许 的 各 种 信息 ,以 实现 人 机 交互 , 它 能 够 根据 
不 同 的 时 间 、 不 同 的 访问 者 显示 不 同 的 内 容 。 采 用 动态 网 页 技术 的 网 站 可 以 实现 更 多 的 功能 ， 
如 用 户 注册 .用户 登录 在线 调查 .用户 管 理 .订单 管理 等 。 

动态 网 页 中 不 仅 含有 HTML 标记 ,还 含有 相关 的 程序 代码 。 本 书 采 用 ASP.NET 设计 
动态 网 页 ,网 页 的 扩展 名 是 aspx, 其 示例 参见 例 1. 1 。 

动态 网 页 的 工作 过 程 与 图 1. 3 类似, 其 步骤 如 下 : 

Q@ 用 户 通过 客户 机 浏览 器 输入 网 址 并 回 车 发 出 WWW 请 求 。 

@ 服务 器 收 到 动态 网 页 请 求 。 

@ 服务 器 从 硬盘 的 指定 位 置 查找 相应 的 动态 网 页 文件 。 

@ 将 在 硬盘 中 找到 的 动态 网 页 文件 返回 给 服务 器 ,服务 器 执行 其 中 的 程序 代码 ,生成 
HTML 文件 。 

@ 服务 器 向 客户 机 返回 该 HTML 文件 。 

@ 客户 机 浏览 器 收 到 请 求 的 文件 ,并 以 图 形 方式 将 HTML 标记 显示 在 计算 机 屏幕 上 。 

从 中 可 以 看 到 ,对 于 动态 网 页 ,服务 器 的 主要 功能 是 通过 文件 系统 找到 用 户 要 访问 的 动态 
网 页 文件 ,执行 该 网 页 文件 的 程序 代码 ,产生 HTML 文件 ,再 将 该 HTML 文件 传 给 客户 机 。 

和 静态 网 页 的 服务 器 相 比 ,动态 网 页 的 服务 器 不 仅 要 查找 动态 网 页 文件 ,还 要 解释 执行 其 
中 的 程序 代码 (对 于 ASP.NET 网 页 ,这 种 程序 代码 是 由 ASP.NET 引擎 执行 的 ; 对 于 静态 网 
页 ,不 需要 这 种 引擎 ) ,将 含有 程序 代码 的 动态 网 页 转化 为 标准 的 静态 网 页 ,然后 将 静态 网 页 发 
送 给 客户 机 。 也 就 是 说 ,动态 网 页 实际 上 并 不 是 独立 存在 于 服务 器 上 的 网 页 文件 ,只 有 当 用户 
请 求 时 服务 器 才 返 回 一 个 完整 的 网 页 ,这 个 返回 的 网 页 事先 并 不 存在 ,而 是 由 引擎 (如 ASP . 
NET 引擎 ) 生 成 的 。 

归纳 起 来 ,静态 网 页 和 动态 网 页 的 比较 如 表 1. 1 所 示 。 从 中 可 以 看 出 ,静态 网 页 和 动态 网 
页 各 有 优 缺 点 ,在 实际 应 用 中 ,开发 人 员 根 据 任 务 的 需要 选择 设计 哪 种 类 型 的 网 页 。 

表 1.1 静态 网 页 和 动态 网 页 的 比较 


比较 项 静态 网 页 动态 网 页 
内 容 网 页 内 容 固定 网 页 内 容 动 态 生 成 
含 程序 代码 ” 无 含 C# 或 VB 等 程序 代码 
后 级 . htm、. html 等 .asp、.jsp、. Php、. cgi、. aspx 等 
优点 无 须 系统 实时 生成 ,网 页 风格 灵活 多 样 日 常 维护 简单 ,更 改 结 构 方 便 , 交 互 性 能 强 
缺点 交互 性 能 较 差 ,日 常 维护 烦琐 需要 大 量 的 系统 资源 合成 网 页 
数据 库 不 支持 支持 


1.1.5 Web 网 页 开发 技术 


WWW 是 一 种 典型 的 分 布 式 应 用 架构 ,其 应 用 中 的 每 一 次 信息 交换 都 要 涉及 客户 端 和 服 
务 端 两 个 层面 ,因此 , Web 网 页 开发 技术 大 体 上 可 以 分 为 Web 客户 端 技术 和 Web 服务 器 端 技 
术 两 大 类 。 

Web 客户 端的 主要 任务 是 展现 信息 内 容 , 而 HTML 语言 则 是 信息 展现 的 最 有 效 的 载体 
之 一 。 最初 的 HTML 语言 只 能 在 浏览 器 中 展现 静态 的 文本 或 图 像 信息 ,满足 不 了 人 们 对 信 
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息 丰富 和 多 样 性 的 强烈 需求 ,因此 ,由 静态 技术 向 动态 技术 的 转变 成 为 Web 客户 端 技术 演进 
的 必然 趋势 。 目 前 ,支持 Web 客户 端 动态 技术 的 语言 主要 有 VBScript 和 JavaScript 脚本 
语言 。 

与 客户 端 技术 从 静态 向 动态 的 演进 过 程 类 似 , Web 服务 器 端的 网 页 开发 技术 也 是 由 静态 
向 动态 逐渐 发 展 、 完 善 起 来 的 。 最 早 的 Web 服务 器 简单 地 响应 浏览 器 发 来 的 HTTP 请 求 , 并 
将 存储 在 服务 器 上 的 HTMIL 文件 返回 给 浏览 器 。 

第 一 种 真正 使 服务 器 能 根据 执行 时 的 具体 情况 动态 生成 HTML 页 面 的 技术 是 CGI 
(Common Gateway Interface, 通 用 网 关 接 口 ) 技 术 。CGI 技术 允许 服务 器 端的 应 用 程序 根据 
客户 端的 请 求 动态 生成 HTML 网 页 ,这 使 客户 端 和 服务 器 端的 动态 信息 交换 成 为 可 能 。 

1994 年 出 现 了 PHP(Hypertext Preprocessor, 超 文本 预 处 理 器 ) 语 言 , 它 将 HTML 代码 
和 PHP 指令 合成 为 完整 的 服务 器 端 动 态 页 面 ,Web 应 用 的 开发 者 可 以 用 一 种 更 加 简便 、 快 捷 
的 方式 实现 动态 Web 功能 。 

1996 年 ,Microsoft 借鉴 PHP 的 思想 ,在 其 Web 服务 器 IIS 3. 0(Internet Information 
Server, Internet 信息 服务 器 ) 中 引入 了 ASP (Active Server Pages, 活跃 服务 器 页 面 ) 技 术 。 
ASP 使 用 脚本 语言 VBScript 和 JavaScript, 借助 Microsoft Visual Studio 等 开发 工具 在 市 场 
上 的 成 功 ,迅速 成 为 Windows 系统 下 Web 服务 器 端的 主流 开发 技术 。 

1997 年 ,Servlet 技术 问世 ,1998 年 ,JSP 技术 诞生 。Servlet 和 JSP 的 组 合 (还 可 以 加 上 
Java Bean 技术 ) 让 Java 开发 者 同时 拥有 了 类 似 CGI 程序 的 集中 处 理 功 能 和 类 似 PHP 的 
HTML 幅 入 功能 。 

2000 年 ,Microsoft 推出 了 基于 .NET Framework 的 ASP.NET 1.0 版 本 ,2002 年 推出 了 
ASP.NET 1.1 版 本 ,2005 年 推出 了 ASP.NET 2.0 版 本 ,2008 年 推出 了 ASP.NET 3.5 版 
本 ,2010 年 推出 了 ASP.NET 4.0 版 本 ,2012 年 又 推出 了 ASP.NET 4. 5 版 本 。 

下 面 简要 介绍 常见 的 几 种 Web 网 页 开发 技术 。 

。 CGI: 一 种 早期 的 动态 网 页 技术 ,可 以 使 用 不 同 的 程序 设计 语言 编写 适合 的 CGI 程序 ， 

如 VB、Delphi 或 C/C++ 等 。 虽然 CGI 技术 已 经 发 展 成 熟 而 且 功能 强大 ,但 由 于 编程 
困难 、 效 率 低 下 、 修 改 复 杂 , 所 以 逐渐 被 新 技术 取代 。 

。 ASP: Microsoft 开发 的 服务 器 端 脚本 环境 ,内 置 于 IIS 3.0 及 以 后 的 版 本 之 中 ,通过 
ASP 可 结合 HTML 网 页 、.ASP 指令 和 ActiveX 组 件 建立 动态 、 交 互 且 高 效 的 Web 服 
务 器 应 用 程序 。 有 了 ASP, 用 户 就 不 必 担 心 客户 浏览 器 是 否 能 执行 所 编写 的 代码 , 因 
为 所 有 程序 都 将 在 服务 器 端 执行 ,包括 所 有 内 在 普通 HTML 中 的 脚本 程序 。 当 程序 
执行 完毕 后 ,服务 器 仅 将 执行 结果 返回 给 客户 浏览 器 ,这 样 也 减轻 了 客户 浏览 器 的 负 
担 , 极 大 地 提高 了 交互 的 速度 。ASP 3. 0 是 经 典 ASP 的 最 后 一 个 版 本 。 

PHP: 一 种 易于 学 习 和 使 用 的 服务 器 端 脚本 语言 ,用 户 只 需要 很 少 的 编程 知识 就 能 使 
用 PHP 建立 一 个 真正 交互 的 Web 网 站 。PHP 不 需要 特殊 的 开发 环境 ,不 仅 支持 多 
种 数据 库 ,还 支持 多 种 通信 协议 。 

JSP: JSP 与 ASP 技术 非常 相似 ,两 者 都 提供 在 HTML 代码 中 混合 某 种 程序 代码 .由 语 
言 引擎 解释 执行 程序 代码 的 功能 。 与 ASP 一 样 ,JSP 中 的 Java 代码 均 在 服务 器 端 执 行 。 
ASP .NET: 它 是 继 ASP 后 推出 的 全 新 的 动态 网 页 制作 技术 ,是 建立 在 .NET 
Framework 的 公共 语言 运行 库 上 的 ,可 用 于 在 服务 器 上 生成 功能 强大 的 Web 应 用 程 
序 。 它 在 性 能 上 比 ASP 强 很 多 ,与 PHP 和 JSP 相 比 也 存在 明显 的 优势 。 
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1.2 ASP.NET 的 基础 知识 


ASP.NET 是 Microsoft 公司 的 一 种 服务 器 端 脚本 技术 ,是 一 种 在 IIS 中 运行 的 程序 ,可 
以 使 (嵌入 网 页 中 的 ?脚本 由 WWW 服务 器 执行 。ASP.NET 不 是 ASP, 而 是 下 一 代 ASP ,不 
是 ASP 的 更 新 版 本 。ASP.NET 是 一 种 建立 动态 网 页 的 技术 ,是 面向 新 一 代 企 业 级 的 网 络 计 
算 Web 平台 , 它 是 .NET Framework 的 一 部 分 ,可 以 使 用 任何 .NET 兼容 的 语言 (如 C#、VB 
等 ) 编 写 ASP.NET 应 用 程序 ,ASP. NET 网 页 进行 编译 可 以 提供 比 脚本 语言 更 出 色 的 性 能 表 
现 。 在 ASP.NET 网 页 中 ,可 以 使 用 ASP.NET 服务 器 端 控件 建立 常用 的 用 户 接口 元 素 ,并 对 
其 进行 编程 ; 可 以 使 用 内 建 可 重用 组 件 和 自 定义 组 件 快 速 建立 Web 网 页 ,从 而 使 代码 极 大 地 
简化 。 相 对 原 有 的 Web 技术 而 言 ,ASP.NET 提供 的 编程 模型 和 结构 有 助 于 快速 .高效 地 建 
立 灵活 、 安 全 和 稳定 的 应 用 程序 。 


1.2.1 ASP.NET 的 特点 


ASP.NET 的 主要 特点 如 下 : 

Q@ ASP.NET 是 和 .NET Framework 集成 在 一 起 的 。 
@ ASP.NET 是 编译 执行 的 ,而 不 是 解释 执行 的 。 

@ ASP.NET 支持 多 语言 。 

@ ASP.NET 运行 在 公共 语言 运行 库 内 。 

@@ ASP.NET 是 面向 对 象 的 。 

@ ASP.NET 支持 所 有 的 浏览 器 。 

@ ASP.NET 易于 部 署 和 配置 。 


1.2.2 ASP.NET 引擎 


在 处 理 动态 网 页 时 ,服务 器 既 要 查找 动态 网 页 文件 又 要 执行 动态 网 页 文件 以 产生 HTML 
文件 ,这 样 负担 过 重 ,通常 将 Web 服务 器 和 动态 网 页 源 代码 的 执行 分 离开 来 。 也 就 是 说 , 当 一 
个 Web 请 求 到 达 时 ,Web 服务 器 确定 所 请 求 的 页 面 是 静态 网 页 还 是 动态 网 页 ,如 果 是 静态 网 
页 , 则 该 网 页 的 内 容 将 直接 被 发 送 到 该 请 求 的 浏览 器 ; 如 果 是 动态 网 页 ,例如 是 一 个 ASP. 
NET 网 页 , 则 Web 服务 器 将 把 执行 该 网 页 的 任务 转交 给 ASP. NET 引擎 ,ASP.NET 引擎 执 
行 ASP.NET 网 页 中 的 程序 代码 ,以 HTML 形式 产生 该 网 页 文件 并 返回 给 Web 服务 器 ， 
Web 服务 器 将 其 返回 给 发 出 Web 请 求 的 客户 机 浏览 器 。 

图 1.4 说 明了 一 个 典型 的 ASP.NET Web 网 页 的 请 求 过 程 。 其 常见 的 配置 是 客户 机 安 
装 有 IE 浏览 器 ; Web 服务 器 配置 有 IIS; 数据 库 服 务 器 安装 有 SQL Server 数据 库 管理 系统 。 
对 图 中 的 各 个 步骤 说 明 如 下 : 

@ 客户 机 通过 浏览 器 发 出 Web 请 求 。 

@ Web 服务 器 收 到 ASP. NET 动态 网 页 请 求 。 

@ Web 服务 器 从 硬盘 的 指定 位 置 查找 相应 的 ASP.NET 动态 网 页 文件 。 

@ 将 在 硬盘 中 找到 的 ASP.NET 动态 网 页 文件 返回 给 Web 服务 器 。 

@@ Web 服务 器 将 ASP.NET 动态 网 页 发 给 ASP. NET 引擎 。 

@ ASP.NET 引擎 逐 行 地 读 取 该 文件 ,并 执行 文件 中 的 程序 代码 (脚本 ), 如 果 需 要 访问 
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数据 库 , 则 将 这 部 分 代码 发 给 数据 库 服 务 器 ; 如 果 不 需要 访问 数据 库 , 则 直接 转 到 步骤 @) 。 

@ 数据 库 服务 器 执行 数据 库 访 问 ,并 将 结果 返回 给 ASP.NET 引擎 。 

@ ASP.NET 引擎 生成 最 终 的 纯 HTML 文件 并 返回 给 Web 服务 器 。 

@ Web 服务 器 将 该 纯 HTML 文件 发 送 给 客户 机 。 

@@ 客户 机 收 到 请 求 的 纯 HTML 文件 ,并 在 浏览 器 中 以 图 形 方式 将 HTML 标记 显示 在 计 
算 机 屏幕 上 。 


Web 服 务 器 
a 天 en = | 
Sr @、`~-- @ 
客户 机 a| | 


[= 0 
用 于 执行 网 页 中 的 程序 代码 一 让 -一 必 


ASP.NET 引 擎 ”数据库 服 务 器 
图 1.4 ASP.NET 网 页 的 执行 由 ASP.NET 引擎 处 理 


从 中 可 以 看 到 ,ASP.NET 网 页 作为 代码 是 在 服务 器 上 执行 的 ,因此 ,网 页 必须 配置 为 当 
客户 引发 交互 时 提交 到 服务 器 。 每 次 网 页 都 会 传 回 服务 器 ,以 便 再 次 执行 其 服务 器 代码 ,然后 
向 客户 呈现 其 自身 的 新 版 本 。 

只 要 客户 在 该 网 页 中 操作 ,此 循环 就 会 继续 。 客 户 每 次 单 击 按钮 时 ,网 页 中 的 信息 便 会 发 
送 到 Web 服务 器 中 ,然后 该 网 页 再 次 执行 。 每 个 循环 称 为 一 次 “往返 行程 ”。 由 于 网 页 处 理发 
生 在 Web 服务 器 上 ,因此 网 页 执行 的 每 个 操作 需要 一 次 到 服务 器 的 往返 行程 。ASP.NET 网 
页 可 以 执行 客户 端 脚 本 ,而 客户 端 脚 本 不 需要 到 服务 器 的 往返 行程 ,这 对 于 客户 输入 验证 和 某 
些 类 型 的 用 户 界面 编程 十 分 有 用 。 


1.2.3 ASP.NET 应 用 程序 的 开发 工具 


读者 从 前 面 可 以 了 解 到 ,开发 ASP.NET 动态 网 页 的 主要 工作 之 一 是 编写 网 页 的 程序 代 
码 。 其 主要 的 开发 工具 是 Visual Studio, 这 里 采用 Visual Studio 2012, 它 提供 的 用 于 开发 
ASP.NET 应 用 程序 的 各 种 版 本 如 表 1. 2 所 示 。 

ASP.NET 引擎 是 一 个 用 于 执行 ASP.NET 网 页 的 软件 ,在 安装 Visual Studio 的 相应 版 
本 后 ,计算 机 便 自动 配置 好 了 ASP.NET 引擎 。 


表 1.2 Visual Studio 2012 开发 ASP.NET 应 用 程序 的 各 种 版 本 


版 本 说 明 

Visual Studio Express 2012 for Web Web 开发 的 免费 版 本 

Visual Studio 2012 专业 版 用 于 创建 Windows、Web、 移 动 和 Office 应 用 程序 

Visual Studio 2012 高 级 版 用 于 个 人 或 团队 开发 ,包括 测试 ,数据库 部 署 . 变 更 和 生命 周期 
管理 的 基本 工具 

Visual Studio 2012 旗舰 版 用 于 团队 开发 ,包括 完整 的 测试 、 建 模 、 数 据 库 部 署 和 生命 周期 


管理 工具 
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1.2.4 ASP.NET 应 用 程序 的 开发 方式 
开发 ASP. NET 应 用 程序 主要 有 如 图 1. 5 所 示 的 3 种 方式 , 即 独 立 、Intranet 和 Internet 
开发 方式 。 
Windows 7 或 更 高 版 本 


.NET Framework 4.5 
Visual Studio 2012 
JIS Express 

SOL Server 


(a) 独立 开发 方式 


Windows Server 2008 R2 或 更 高 版 本 
Windows 7 或 更 高 版 本 .NET Framework 4.5 
NET Framework 4.5 lIS 7.0 或 更 高 版 本 


关 Visual Studio 2012 SQL Server 融 # 服 
. i 时 | 务 
和 遇 局 域 网 连接 加 如 


(b) Intranet 开 发 方式 


Windows Server 2008 R2 或 更 高 版 本 
.NET Framework 4.5 

Windows 7 或 更 高 版 本 IIS 7.0 或 更 高 版 本 

.NET Framework 4.5 FTP 服 务 器 


客 Visual Studio 2012 SQL Server Ey 服 
卢 互联 网 连接 i 务 
机 句 


(©) Internet 开 发 方式 
图 1.5 开发 ASP.NET 应 用 程序 的 3 种 方式 


在 独立 开发 方式 中 ,采用 的 计算 机 既是 服务 器 又 是 客户 机 ,需要 配置 客户 端 软件 , 如 
Windows 7 或 更 高 版 本 ( 带 有 浏览 器 ) ,又 要 配置 服务 端 软件 ,如 .NET Framework 4.5、Visual 
Studio 2012 IIS Express(Visual Studio 内 置 的 轻 量 级 的 IIS) 和 SQL Server( 如 果 网 页 需要 访 
问 SQL Server 数据 库 ) 等 。 

在 Intranet 开发 方式 中 ,客户 机 与 服务 器 通过 局 域 网 通信 ,为 此 ,服务 器 还 需要 安装 
FPSE (FrontPage Server Extensions，FrontPage 服务 扩展 ) 或 WebDAV (Web-based 
Distributed Authoring and Versioning, 基 于 Web 的 分 布 式 创作 和 版 本 控制 ) ,它们 提供 了 作 
为 管理 员 所 需要 的 工具 ,以 便 管 理 网 站 安全 .将 内 容 组 织 进 子 网 站 以 及 检查 网 站 的 使 用 情 

在 Internet 开发 方式 中 ,客户 机 与 服务 器 通过 因特网 通信 ,为 此 ,服务 器 还 需要 配置 成 
FTP 服务 器 ,以 方便 客户 端 与 服务 端 传送 文件 。 

说 明 : 当前 程序 员 只 能 通过 Visual Studio 自 带 的 ASP.NET 开发 服务 器 (webdev. exe) 
或 IIS 两 种 Web 服务 器 之 一 来 开发 和 测试 ASP.NET 网 站 程序 ,这 两 个 方案 各 有 优 缺点 ,而 
ASP.NET 程序 员 希 望 有 一 个 像 ASP.NET 开发 服务 器 那样 容易 使 用 ,但 是 功能 又 跟 JIS 一 样 
强大 的 服务 器 。IIS Express 就 是 另 一 个 新 的 免费 的 、 综 合 了 这 两 个 方案 优点 的 选择 , 它 的 出 
现 使 得 开发 和 运行 ASP.NET 网 站 程序 变 得 更 为 容易 。IIS Express 支持 Visual Studio , 可 以 
运行 在 Windows XP 和 更 高 的 版 本 上 , 它 不 需要 管理 员 权 限 即 可 运行 ,也 不 要 求 代码 做 任何 改 
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动 ,可 以 用 它 开发 所 有 类 型 的 ASP.NET 程序 ,而 且 它 还 支持 完整 的 IIS 功能 集 。 

本 书 的 示例 采用 独立 开发 方式 ,本 机 上 安装 有 Windows 7(IE 浏览 器 版 本 11)、.NET 
Framework 4. 5、Visual Studio 2012 (安装 Visual Studio 2012 时 自动 安装 IIS Express) 和 
SQL Server 2012。 


1.3 .NET Framework 


.NET Framework 是 Microsoft 公司 的 XML Web 服务 的 平台 ,是 新 一 代 Internet 计算 模 
型 ,各 个 Web 服务 之 间 彼 此 是 松散 耦合 的 ,通过 XML 进行 通信 ,协同 完成 某 一 特定 的 任务 。 


1.3.1 .NET Framework 体系 结构 


.NET Framework 的 体系 结构 如 图 1.6 所 示 。 


1. 公共 语言 规范 (简称 为 CLS) 

.NET Framework 中 定义 了 一 个 CLS, 包含 函 Ce) Co) er) Ged 
数 调用 方式 、 参 数 传递 方式 、 数 据 类 型 和 异常 处 理 方 公共 语言 规范 (CLS) 
式 等 。 在 进行 程序 设计 时 ,如 果 使 用 符合 CLS 的 开 ET 
发 语言 ( 称 为 .NET 兼容 语言 ,如 C#H 、VB 等 ), 那 么 Windows 徐 体 
所 开发 的 程序 可 以 在 任何 公共 语言 开发 环境 的 操作 
系统 下 执行 。 

2. ASP.NET 和 Windows 窗 体 

在 .NET Framework 中 有 两 种 方式 可 以 设计 应 
用 程序 界面 , 即 Web(Web 网 页 和 Web 服务 ) 和 
Windows 窗 体 。 而 Web 网 页 是 以 ASP. NET 为 基 
础 ,ASP.NET 将 许多 控件 加 以 对 象 化 ,使 得 用 户 更 加 方便 地 使 用 各 个 控件 的 属性 、 方 法 和 事 
件 。Web 服务 是 一 种 程序 调用 与 执行 的 方式 ,该 程序 是 以 网 站 为 基础 的 ,一 个 应 用 程序 可 以 
通过 Web 服务 主动 调用 网 络 上 的 另 一 个 应 用 程序 。 

3. ADO .NET 和 XML 

.NET Framework 直接 支持 ADO.NET( 数 据 库 访问 接口 ) 和 XML 文件 的 操作 。 在 
XML 文档 和 数据 集 之 间 可 以 进行 数据 转换 ,甚至 共享 一 份 数据 ,程序 员 可 以 选择 熟悉 的 方式 
处 理 数据 ,以 提高 程序 的 设计 效率 。 

4. .NET 类 库 

在 程序 开发 过 程 中 ,会 有 许多 功能 组 件 被 重复 使 用 ,于 是 将 这 些 组 件 制作 成 类 库 ,每 一 种 
程序 设计 语言 都 拥有 各 自 独立 的 类 库 , 如 C++ 的 MFC Java 的 JDK 等 ,然而 每 一 种 类 库 都 是 
针对 一 种 语言 的 ,所 以 这 些 类 库 彼 此 之 间 并 不 能 互相 引用 ,对 于 偏好 VB 的 程序 员 而 言 , 所 开 
发 的 类 库 就 无 法 被 C++ 程序 员 使 用 。 

.NET Framework 提供 了 一 个 巨大 的 统一 类 库 , 该 类 库 提供 了 程序 员 在 开发 程序 时 所 需 
要 的 大 部 分 功能 ,而 且 这 个 类 库 可 以 使 用 任何 一 种 .NET 兼容 语言 加 以 引用 ,程序 员 不 再 需要 
为 了 不 同 的 类 库 而 学 习 不 同 的 程序 设计 语言 。 

.NET 类 库 是 以 面向 对 象 为 基础 创建 的 ,其 实在 .NET Framework 下 ,不 管 是 数字 还 是 字 
符 串 ,所 有 的 数据 都 是 对 象 .. NET 类 库 结构 是 阶层 式 的 ,采用 命名 空间 加 以 管理 ,方便 程序 员 


ADO.NET 和 XML 


公共 语言 运行 库 (CLR) 


而 关 习 水 半 如 站 oIPmS [ensI 和 A 


.NET 类 库 (CU) | 
| 


图 1.6 .NET Framework 体系 结构 
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进行 分 类 引用 。 

5. 公共 语言 运行 库 ( 简 称 为 CLR) 

在 .NET Framework 下 ,所 有 的 .NET 兼容 语言 将 使 用 统一 的 虚拟 机 ,CLR 将 是 所 有 的 
兼容 .NET 语言 在 执行 时 所 必 备 的 运行 环境 ,这 种 统一 的 虚拟 机 与 运行 环境 可 以 达到 跨 平台 
的 目标 。 


1.3.2 .NET Framework 下 应 用 程序 的 开发 和 执行 


在 .NET Framework 下 可 以 使 用 多 种 兼容 语言 进行 应 用 程序 的 开发 .. NET Framework 
中 的 CLR 实际 上 是 一 种 语言 规范 , 它 大 致 可 以 分 为 以 下 几 个 部 分 。 
。 通用 类 型 系统 (Common Type System,CTS): 其 作用 是 使 所 有 的 .NET 兼容 语言 共享 
相同 的 数据 类 型 。 无 论 程序 是 采用 哪 种 .NET 兼容 语言 编写 的 ,都 会 被 编译 成 相同 的 
与 平台 机 器 无 关 的 中 间 语 言 (IL 或 MSIL) , 称 为 第 1 次 编译 。 中 间 语 言 中 采用 统一 的 
数据 类 型 ,从 而 使 不 同 语言 之 间 的 数据 得 以 沟通 协调 。 
。 内 存 管理 和 资源 回收 机 制 : 支持 .NET Framework 且 遵 守 共 同 规范 的 程序 语言 所 编 
写 的 程序 , 称 之 为 managed code( 托 管 代 码 )。 也 就 是 说 ,在 Visual Studio 中 编写 的 
.NET Framework 规范 的 代码 都 是 托管 代码 。 托 管 代 码 在 执行 过 程 中 使 用 到 的 内 存 
资源 受到 CLR 的 监控 ,各 种 数据 与 对 象 的 生存 期 都 由 CLR 管理 。CLR 提供 了 统一 的 
资源 回收 机 制 ,对 于 不 再 使 用 的 对 象 等 会 自动 释放 所 使 用 的 资源 ,避免 造成 程序 错误 
或 内 存 耗损 。 
。 中 间 语 言 与 即时 编译 器 : 在 .NET Framework 下 ,第 1 次 编译 的 中 间 语 言 代码 与 原 数 
据 一 起 被 即时 编译 器 编译 成 可 执行 的 本 机 代码 , 称 为 第 2 次 编译 。 该 本 机 代码 可 以 在 
任何 安装 .NET Framework 的 机 器 上 执行 。 
同时 .NET Framework 负责 管理 兼容 语言 创建 的 应 用 程序 的 执行 ,如 图 1.7 所 示 , 所 以 应 
用 程序 的 开发 需要 安装 Visual Studio 开发 环境 , 而 应 用 程序 的 执行 只 需要 安装 .NET 
Framework 即 可 。 


:NET 应 用 程序 代码 


CH 代码 ] | VB 代码 | | 
1 
EH [ai 译 器 ] 区 一 人 


IL 中 间 语 言 代码 


JIT 即 时 编译 器 
第 2 次 编译 


本 机 代码 


| 执行 
操作 系统 


图 1.7 托管 代码 的 执行 过 程 


CLR 
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1.4 创建 ASP.NET 应 用 程序 


1.4.1 ASP.NET 应 用 程序 的 项 目 类 型 


Visual Studio 提供 了 两 种 创建 ASP.NET 应 用 程序 的 方法 ,用 于 创建 两 种 不 同类 型 的 
ASP.NET 应 用 程序 。 

1. 基于 项 目的 开发 一 一 Web 项 目 

在 创建 一 个 Web 项 目 时 ,Visual Studio 生成 一 个 . csproj 项 目 文 件 (假设 使 用 C# 编程 )， 
它 记 录 项 目 中 的 文件 并 保存 一 些 调试 设置 。 运 行 Web 项 目 时 ,Visual Studio 在 启动 Web 浏 
览 器 前 把 项 目的 所 有 代码 编译 成 一 个 程序 集 。 

创建 一 个 Web 项 目的 操作 是 启动 Visual Studio 2012, 选 择 “ 文 件 | 新 建 | 项 目 ” 命 令 , 出 现 
“新 建 项 目 ” 对 话 框 , 单 击 模 板 列表 中 Visual C# 下面 的 Web 项 , 列 出 已 安装 的 Web 项 目 模 
板 , 如 图 1.8 所 示 。 用 户 可 以 选择 "ASP.NET 空 Web 应 用 程序 ”模板 进行 Web 项 目的 开发 ， 
此 时 需要 输入 一 个 位 置 , 它 可 以 是 文件 路 径 , 也 可 以 是 指向 本 地 或 远 端 ITIS 服务 器 的 URL。 


me) 


.NET Framework 4.5 。 排序 依据 财 认 值 


aspner wc 3 web epg 

[= | ASP.NET MVC 4 Web 应 用 得 序 

spNer Dymomic Dato zx web EB 
[i 


化 “soner nn sm Re 


图 1.8 Web 项 目的 模板 


2. 无 项 目 文件 的 开发 一 一 网 站 

创建 一 个 没有 任何 项 目 文件 的 网 站 ,此 时 ,Visual Studio 认为 在 网 站 目录 (及 其 子 目录 ) 
里 的 所 有 文件 都 是 Web 应 用 程序 的 一 部 分 。 在 这 种 情况 下 , Visual Studio 可 以 不 预 编译 代 
码 , 而 是 由 ASP.NET 在 第 一 次 请 求 网 页 时 编译 网 站 (当然 可 以 进行 预 编译 ) 。 

创建 一 个 网 站 的 操作 是 启动 Visual Studio 2012 ,选择 “ 文 件 | 新 建 | 网 站 ”命令 ,出 现 “ 新 建 
网 站 ”对 话 框 , 单 击 模板 列表 中 的 Visual C# 项 , 列 出 已 安装 的 网 站 模板 ,如 图 1.9 所 示 , 对 各 
网 站 模板 的 说 明 如 下 。 
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es 


图 1.9 网 站 的 模板 


ASP.NET 空 网 站 : 该 模板 只 包含 一 个 配置 文件 (Web. config)。 本 书 中 主要 使 用 该 模 
板 构 建 网 站 示例 ,并 逐步 添加 文件 和 目录 。 

ASP.NET 窗 体 网 站 : 该 模板 用 于 配置 一 个 基本 的 ASP.NET 网 站 ,包含 许多 文件 和 
目录 ,用 于 窗 体 网 站 的 开发 。 

ASP.NET 网 站 (Razor vl 或 Razor v2) : 通过 Microsoft 的 Web Pages 框架 ,使 用 这 些 
模板 创建 网 站 。 

ASP.NET Dynamic Data 实体 网 站 : 该 模板 用 于 创建 灵活 且 强大 的 Web 网 站 来 管理 
数据 库 中 的 数据 ,而 不 需要 手工 输入 许多 代码 。 

WCF 服务 : 该 模板 用 于 创建 包含 一 个 或 多 个 WCF 服务 的 网 站 。 

ASP.NET 报表 网 站 : 该 模板 用 于 创建 企业 报表 网 站 。 


“新 建 网 站 ”对话 框 中 “Web 位 置 " 选 项 有 如 下 3 种 。 


文件 系统 : 如 果 主 机 没有 安装 IIS, 也 不 想 设置 服务 器 的 位 置 等 信息 ,可 以 使 用 这 个 设 
置 ,表示 代码 源 文件 放 在 选 定 的 本 地 文件 目录 中 。YVisual Studio 会 把 用 户 所 指定 的 路 
径 视 为 该 网 站 的 根 目录 ,并 在 预览 时 启动 内 置 的 网 页 服务 器 ,根据 这 个 位 置 来 模拟 执 
行 ,并 可 以 很 方便 地 进行 程序 源 代码 的 移植 。 

HTTP: 如 果 主 机 已 经 安装 了 IIS, 便 可 以 使 用 这 个 设置 。 这 个 设置 与 IIS 的 设置 相 
关 , 还 必须 设置 网 页 服务 器 的 预览 网 址 ,所 设计 的 文件 也 会 放置 在 IIS 所 设置 网 站 的 
根 目录 中 。 

FTP: 如 果 测 试 主机 并 不 在 本 机 上 ,可 以 使 用 这 个 设置 ,表示 将 代码 源 文 件 保存 在 远 
程 的 FTP 服务 器 上 。Visual Studio 通过 文件 传输 协议 FTP 访问 网 站 ,这 样 更 容易 访 
问 其 他 服务 器 上 的 网 站 。 在 第 一 次 运行 FTP 网 站 时 会 提示 用 户 指定 服务 器 URL。 
两 种 不 同类 型 ASP.NET 应 用 程序 的 比较 


两 种 不 同类 型 ASP.NET 应 用 程序 的 比较 如 表 1. 3 所 示 。 一 般 来 说 ,基于 项 目的 Web 开 
发 比 无 项 目 文件 的 网 站 开发 更 严格 ,因为 项 目 文件 显 式 地 列 出 了 哪些 文件 是 项 目的 一 部 分 , 容 
易 捕 获 到 潜在 的 错误 ( 若 丢失 的 文件 ) 甚 至 恶意 的 破坏 .并且 人 允许 更 灵活 的 文件 管理 (如 将 几 个 
单独 的 项 目 放 在 同一 个 虚拟 目录 的 不 同 子 目录 中 ) 。 
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表 1.3 两 种 不 同类 型 ASP.NET 应 用 程序 的 比较 
比较 项 网 站 应 用 程序 
项 目 文件 无 一 个 或 多 个 
编译 方式 在 运行 时 编译 预 编译 成 单个 程序 集 
类 文件 位 置 App_Code 目录 任意 目录 
启动 操作 “文件 | 新 建 | 网 站 ”命令 “文件 | 新 建 | 项 目 ” 命 令 


而 无 项 目 文件 的 网 站 开发 不 仅 简化 了 文件 管理 ,而 且 简化 了 调试 和 部 署 过 程 ,适合 团队 协 
作 。 同 时 ,无 项 目 文件 的 网 站 开发 允许 混合 使 用 语言 。 

本 书 的 示例 主要 采用 无 项 目 文件 的 网 站 开发 类 型 ，Web 位 置 ? 采 用 "文件 系统 ”, 这 是 一 
种 非常 适合 初学 者 的 ASP.NET 应 用 程序 开发 方法 。 


1.4.2 设计 第 一 个 网 站 


本 小 节 通 过 一 个 简单 示例 说 明 ASP.NET 网 站 和 网 页 的 设计 过 程 。 
【 例 1.1】 在 D 盘 ASP.NET 目录 中 建立 一 个 chl 的 子 目录 ,将 其 作为 网 站 目录 ,然后 创 
建 一 个 WebForml 网 页 ,其 功能 是 在 用 户 单 击 其 中 的 “ 单 击 " 按 钮 时 提示 相应 的 信息 。 


解 : 其 步骤 如 下 。 


QO@ 启动 Visual Studio 2012 。 
@ 选择 "文件 | 新 建 | 网 站 ”命令 ,出现 如 图 1.9 所 示 的 “新 建 网 站 ”对 话 框 ,然后 选择 “ASP 
.NET 空 网 站 ”模板 ,选择 “Web 位 置 ”为 “文件 系统 ”, 单 击 “ 浏 览 ” 按 钮 ,选择 “D:\ASP.NET\ 


ch1” 目 录 , 单 击 “ 确 定 ” 按 钮 。 


@ 出 现 如 图 1. 10 所 示 的 界面 ,其 中 只 有 一 个 Web. config 配置 文件 ,这 表示 创建 了 一 个 
空 的 网 站 chl 。 下 面 在 该 网 站 中 添加 网 页 ,选择 “网 站 | 添加 新 项 "命令 ,出 现 如 图 1. 11 所 示 的 


dh -Microsop Visual Swdio(BaR) 


-9 了- 自 入 中 TS- 
工具 类 9 
规 罕 工具 条 Pp- 
此 组 中 没有 可 用 的 控件 
往 基 项 抱 至 此 文本 可 将 其 


十 加 到 工具 杆 . 


文件 月 。 篇 得 (E) 视图 [V) 网 站 (S) 生成 (B) 再 坛 (D) EIM) IRAM WS) WN) ROW Bm(H) 
internet Explorer - Debug - 瑞 - 


全 启动 (col+Q p= Ox 


吉方 芋 天 合理 路 -ox 
oo8 B®-7 8080» 
提要 角 方案 容 源 管理 器 (Cul+ Pp- 


团 乱 * 方 客 “chl” (1 个 项 目 ) 


hapy/localhost50922/ 。 固 
BaA 


各 他 这 检 式 交友 目 
DAASP.NET\chl | 
False 


Be SSL 


En Pp 


图 1.10 新 建 一 个 空 网 站 chl 
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“添加 新 项 -chl ”对话 框 ,在 中 间 列 表 中 选择 " Web 窗 体 ”, 将 文件 名 称 改 为 WebForml. aspx, 保 
持 “ 将 代码 放 在 单独 的 文件 中 ” 复 选 框 的 默认 勾 选 , 单 击 " 添 加 ”按钮 。 


六 实 已 安装 楼 板 (Ctri+E) 


四 


要 弄 :Visual C# 
Web 应 用 导 序 的 窗 体 


图 1.11 “添加 新 项 -ch1” 对 话 框 


@ 出 现 WebForml 网 页 的 源 视图 ,进入 HTML 代码 编辑 窗口 ,如 图 1. 12 所 示 。 单 击 中 
部 下 方 的 5 襄 + 选项 卡 进 入 设计 视图 , 即 进 入 窗 体 设 计 窗 口 。 

0 da - Microsof Visual Studio(Eam) 快速 启动 (Cul+Q) PE 
文件 月 。 篇 回 (E) 。 视 四 (V) 网 站 (S) ”生成 (B) ”调试 (D) 。 国内 (M) 工具 。 油 坛 (S) 分 析 (N) 窗口 (W) 。 大 号 (H) 

日 名 多 | pocrypE: XHTML5 - = 

有 -人 有 四- 血 国 由 了 -RS- intermetEmplorer -Debug - 夺 - 
工 RM bi “解决 方 案 次 源 管理 器 vx 
种 过 工具 箱 Pp Wa Page Language= rt oFvent tt 下 Oral oof B+-#0am rp 
be H <IDOCTYPE htnl> 八 委 解 夫 方 室 资 源 生理 器 (Ctrl+) Be 
Nt 

人 间 解 方 宏 “chl”(1 个 项 目 ) 
1 xalns="http://wws, w3, org/ 1999/xhtnl”> 

ee | ead ren hee 

EE Bulletedlist ‘neta http-equiv="Content-Type” content="texrt/htal; charset=utf-8"/3 on 

国 Button title></title> b A WebFormlaspx 

四 Calendar Le 

国 CheckBox forn id-"fornl” runat="server”> 属性 “ ERROR 二 全 
EE chedkpoxlis 自 <div <PAGE> 

国 DropDownlist di 时 国 |s 

徊 FleUpload /forny a 了 
至 Hiddenfeld a ee 下 
A Hyperlink AsyncTimeout 

国 Image AutoEventWireup True 

国 imageButon 四 Buffer - 
加 ImageMap 00 9。 ”14 RPR 四 

A Label 设计 | 已 拆 分 [下 | [4] <%@ Page%> 

国 LinkButon 

TTT 
= i D1 | 0 | 0 01We 村 异 识 列 下 人 
人 OO 
天 (5}: -| 要 | 生生 | 苦 | 咎 


图 1.12 WebForml 网 页 的 源 视图 
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@ 在 二 body> 部 分 的 第 1 行 输入 “我 的 第 一 个 ASP.NET 网 页 文字。 选择 工具 箱 中 的 
国 Button 控件 ,将 其 拖 放 到 第 2 行 ,从 而 放置 一 个 命令 按钮 Button1, 然 后 右 击 它 ,在 出 现 的 快 
捷 菜单 中 选择 “属性 ”命令 ,设置 它 的 Text 属性 为 “ 单 击 ”, 设 置 其 字体 属性 如 图 1. 13 所 示 。 再 
选择 工具 箱 中 的 入 ”Label 控件 ,将 其 拖 放 到 第 3 行 ,从 而 放置 一 个 标签 Labell ,将 其 Text 属 
性 设置 为 空 .字体 属性 设置 为 “楷体 ,Small”。WebForml 网 页 的 设计 视图 如 图 1. 14 所 示 。 


Buttonl System.Web.ULWebControls.Butto - 
加 区 ][B]# 2 
= EE 天体, sm ~ 
Bold True 
Falic False 
Name 国 及 
Names 黑体 
Overline False - 
Size Small =» 
Strikeout False 我 的 第 一 个 ASP. NET 网 页 | 
Underline False 单 击 ， 
Soalor abell] 
一 一 | 
4 i 
设计 | 日 折 分 | 源 | |4] <aspilabel#label|>] 
图 1.13 设置 Buttonl 的 字体 属性 图 1.14 WebForml 网 页 的 设计 视图 


@ 单 击 中 部 下 方 的 源 选项 卡 进入 源 视图 ,其 结果 如 图 1. 15 所 示 , 它 反映 了 前 面 的 设 
计 , 即 将 开发 人 员 的 设计 操作 转换 为 ASP. NET 网 页 文件 。 


Ce” atolventWireup= true™ CodoFile= VebFornl. pr. cr” Inherit== VebFomnl” WY 
"> 
Chead runat="server”》 
《meta http-equive’Content-Type” content="texzt/htal, charset=utf-8"/> 
Stitley /title> 
/head 
《body> 
《form id"fornl” runat="server”> 
Cdiv> 


我 的 第 一 个 4SP. IET 同 页 cbz />》 
Casp:Button ID="Buttonl” runat=" 


ver” Font-Bold=" True”Font-Nanes=" 黑 体 ”Font-Size="Snall”OnClick="Buttoni_Click”Text=" 单 者" /》 


ver” Fort-Bold="False” Font-lianes=" 杠 仁 ” Font-Size="Saall”></asp:Label> 


图 1.15 WebForml 网 页 的 源 视图 


ASP.NET 网 页 文件 类 似 HTML 文件 ,可 以 包含 HTML、XML 以 及 脚本 。ASP. NET 
网 页 文件 中 的 脚本 在 服务 器 上 执行 ,其 文件 扩展 名 是 aspx。 

@ 再 次 进入 网 页 的 设计 视图 ,双击 Button1, 出 现 程序 代码 编辑 窗口 ,其 中 绝 大 部 分 代码 
是 Visual Studio 自动 产生 的 ,在 Button1_Click 事件 过 程 中 输入 “Labell. Text 一 “您 单 击 了 
按钮 ";” 一 行 ,如 图 1. 16 所 示 。 

说 明 : 在 解决 方案 资源 管理 器 中 可 以 看 到 WebForml 网 页 对 应 的 两 个 文件 是 
WebForml. aspx 和 WebForml. aspx. cs。 

这 样 WebForml 网 页 设计 完毕 ,用 户 可 以 在 浏览 器 中 预览 网 页 。 使 用 F5 键 或 单 击 工 
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WebFormlaspx* 
ts WebForml -|®, Buttonl Click(object sender EventArgs e) 
Busing Systen; 
using System.Collections.Generic; 


1 
2 

3 |using System.Linq; 

4 | using Systen. Web; 

5 |using Systen. Web. UT; 

6 |using Systen. Web.UI. WebControls:; 
7 


8 日 public partial class WebFornl : System. Web.UI.Page 
{ 


protected void Page_Load(object sender, EventArgs e) 


Dm 
0 
| ，| 4 


13 } 
141 6 protected void Buttonl_Click (object sender, EventArgs e) 


15 { 
16 Labell. Text = “您 单 击 了 按钮 
17 } 


L100 % ~ [2 


1.16 WebForml 网 页 的 程序 代码 


有 具 栏 中 的 PInternetExplorer -按钮 ,表示 在 调试 状态 浏览 网 页 。 在 第 一 次 运行 时 ,系统 会 询问 是 否 
要 在 Web. config 文件 中 添加 调试 功能 ,如 图 1. 17 所 示 , 单 击 “ 确 定 ” 按 钮 即 可 ,这 样 在 以 后 浏 
览 时 就 不 再 出 现 询问 对 话 框 。 如 果 使 用 Ctrl 十 F5 键 ,表示 在 非 调试 状态 浏览 网 页 ,会 立即 出 
现 WebForml 网 页 的 浏览 界面 。 


图 1. 17 “未 启用 调试 "对 话 框 


@ 在 浏览 器 中 预览 网 页 时 单 击 “ 单 击 ” 按 钮 ,在 该 按钮 的 下 方 会 显示 “您 单 击 了 按钮 ”, 如 
图 1.18 所 示 。 


[i 
< 全 EEC 


a ads | 我 的 第 一 个 Asp NET 风 页 
一 | 
息 单 吉 了 狐 乌 


(8) 初始 网 页 (b) 最 终 网 页 。 
1.18 在 正 浏览 器 中 操作 WebForml 网 页 


1.4.3 Web 应 用 程序 集成 开发 环境 
Web 应 用 程序 集成 开发 环境 的 组 成 部 分 如 下 。 
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1. 菜单 栏 


它 继 承 了 所 有 可 用 的 Visual Studio 命令 , 除 “ 文 件 ”“ 编 辑 ”“ 视 图 ”、“ 窗 口 * 和 “帮助 " 菜 
单 外 ,还 提供 了 编程 专用 的 功能 菜单 ,如 “网 站 ”“ 生 成 “调试 “工具 ”和 “测试 ”等 。 

2. 标准 工具 栏 

在 菜单 栏 下 方 就 是 标准 工具 栏 , 通 过 它 可 以 快速 访问 常用 的 菜单 命令 等 。 这 里 有 两 排 按 
钮 ,上 排 按 钮 用 于 排版 和 字体 设置 等 ,下 排 按钮 用 于 新 建 项 目 、 打 开 文 件 等 。 

例如 在 设计 网 站 时 ,可 以 单 击 标准 工具 栏 中 的 国 按 钮 保存 当前 的 网 页 文件 , 单 击 晶 按 钮 
保存 当前 网 站 的 所 有 文件 。 

3. 控件 工具 箱 

集成 开发 环境 的 左边 是 控件 工具 箱 , 其 中 把 开发 Web 网 页 所 使 用 的 控件 图 标 分 类 列 出 ， 
用 户 可 以 直接 使 用 这 些 控 件 , 只 需要 将 控件 拖 放 到 网 页 的 设计 界面 上 即 可 , 极 大 地 节省 了 编写 
代码 的 时 间 , 加 快 了 程序 设计 的 速度 。 

4. 解决 方案 资源 管理 器 

集成 开发 环境 的 右边 是 “解决 方案 资源 管理 器 ”窗口 , 它 提 供 了 网 站 项 目 及 其 文件 的 有 组 
织 的 视图 ,并 且 提 供 了 对 项 目 和 文件 相关 命令 的 便捷 访问 ,可 以 方便 地 创建 文件 和 目录 。 解 决 
方案 资源 管理 器 采用 树 视图 结构 ,如 果 要 将 文件 与 解决 方案 而 不 是 与 特定 的 项 目 关 联 ,只 需 将 
文件 直接 添加 到 解决 方案 中 。 

5. HTML 代码 编辑 窗口 

HTML 代码 编辑 窗口 用 于 设计 或 显示 网 页 的 HTML 代码 。 开 发 人 员 可 以 直接 输入 和 修 
改 HTML 代码 进行 网 页 设计 ,其 下 方 有 3 个 选项 卡 。 

。 设计 : 单 击 它 时 进入 当前 网 页 的 设计 视图 。 

。 。 源 : 单 击 它 时 进入 当前 网 页 的 源 视图 。 

。 上 日 折 分 : 单 击 它 时 同时 出 现 源 视图 (上 方 ) 和 设计 视图 (下 方 ) ,在 开发 人 员 操 作 时 两 部 

分 存在 联动 ,以 方便 网 页 设计 。 

通过 单 击 上 述 选项 卡 ,开发 人 员 可 以 在 设计 视图 和 源 视图 之 间 方 便 地 切换 ,设计 出 美观 的 
网 页 界面 ,本 书 将 在 第 2 章 介 绍 HTML 网 页 设计 方法 。 

6. 窗 体 设计 器 

在 网 页 处 于 设计 视图 时 启动 窗 体 设 计 器 ,开发 人 员 可 以 进行 可 视 化 网 页 设计 。 例 如 ,简单 
地 从 控件 工具 箱 拖 放 控 件 到 网 页 中 来 创建 网 页 元 素 等 。 其 操作 类 似 于 FrontPage 和 
Dreamweaver 等 网 页 设计 工具 。 

7. 程序 代码 编辑 窗口 

在 窗 体 设计 器 中 的 某 个 控件 上 双击 ,进入 程序 代码 编辑 窗口 ,开发 人 员 可 以 设计 相应 的 事 
件 处 理 过 程 。 采 用 的 编程 语言 有 C# 、VB 等 .NET Framework 兼容 语言 ,本 书 采用 C# 语 言 ， 
将 在 第 3 章 介 绍 C# 语 言 程序 设计 方法 。 

8. 属性 窗口 

集成 开发 环境 的 右 下 方 是 属性 窗口 ,通过 它 可 以 对 网 页 的 一 些 属性 值 进行 设置 ,这 些 属性 
值 也 会 自动 添加 到 HTML 源 代码 中 ,属性 值 还 会 随 选取 对 象 的 不 同 而 改变 。 

9. 错误 列表 窗口 

在 集成 开发 环境 的 中 部 下 方 是 错误 列表 窗口 ,用 于 报告 代码 中 检测 到 的 、 尚 未 解决 的 错误 。 

在 Visual Studio 集成 开发 环境 中 ,开发 人 员 可 以 通过 拖 动 等 操作 十 分 方便 地 改变 各 个 窗 
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口 的 位 置 和 大 小 ,以 定制 自己 的 集成 开发 环境 。 
1.4.4 ASP.NET 网 页 代码 编写 模型 


在 ASP.NET 网 页 中 ,用 户 的 编程 工作 分 为 两 个 部 分 , 即 可 视 元 素 和 编程 逻辑 。 可 视 元 素 
部 分 由 包括 标记 、 服 务 器 控件 和 静态 文本 的 文件 组 成 ,而 编程 逻辑 部 分 包括 事件 处 理 程序 和 其 
他 代码 ,这 些 代码 由 用 户 创建 与 网 页 进行 交互 。 程 序 代码 可 以 驻 留 在 网 页 的 script 块 中 或 者 
单独 的 类 中 。 如 果 代 码 在 单独 的 类 文件 中 , 则 该 文件 称 为 “代码 隐藏 "文件 。 在 本 书 中 编程 多 
辑 代码 使 用 C# 语 言 编写 。 

因此 ,ASP.NET 提供 了 两 种 代码 编写 模型 , 即 代码 隐藏 页 模型 和 单 文件 页 模型 。 这 两 个 
模型 功能 相同 ,在 两 种 模型 中 可 以 使 用 相同 的 控件 和 代码 。 

1. 代码 隐藏 页 模型 

通过 代码 隐藏 页 模型 ,可 以 在 一 个 文件 (* . aspx) 中 存放 标记 ,并 在 另 一 个 文件 (* . aspx. 
cs) 中 存放 编程 代码 。 代 码 文件 的 名 称 会 根据 所 使 用 的 编程 语言 有 所 变化 。 

这 种 模型 的 优点 是 可 以 清楚 地 分 隔 标记 (CHTML 代码 ) 和 代码 (编程 逻辑 ) ,适用 于 包含 大 
量 代码 或 多 个 开发 人 员 共 同 创建 网 站 的 Web 应 用 程序 ; 便于 程序 的 维护 和 升级 ; 程序 代码 可 
在 多 个 网 页 中 重用 等 。 

在 前 面 的 例 1. 1 中 ,WebForml 网 页 就 是 采用 这 种 网 页 代码 编写 模型 ,本 书 的 示例 大 部 分 
采用 这 种 模型 。 

2. 单 文件 页 模型 

在 单 文件 页 模型 中 ,网 页 的 标记 及 其 程序 代码 位 于 同一 个 . aspx 文件 中 ,也 称 为 内 联 模 
型 。 程 序 代码 位 于 script 块 中 ,该 块 包含 runat 二 "server" 属 性 ,此 属性 将 其 标记 为 ASP. NET 
应 执行 的 代码 。 

【 例 1.2】 在 例 1.1 建立 的 chl 网 站 中 创建 一 个 WebForm2 网 页 ,采用 单 文件 页 模型 ,其 
功能 与 WebForml 网 页 相同 。 

解 : 其 步骤 如 下 。 

@ 在 chl 网 站 中 选择 “网 站 | 添加 新 项 "命令 ,出 现 “ 添 加 新 项 -ch1” 对 话 框 ,在 中 间 列 表 中 
选择 "Web 窗 体 ”, 将 文件 名 称 改 为 WebForm2. aspx, 注 意 去 掉 “ 将 代码 放 在 单独 的 文件 中 ” 复 
选 框 的 默认 色 选 , 单 击 “ 添 加 ”按钮 。 

@ 单 击 s 谢 + 选项 卡 进 入 网 页 的 设计 视图 ,将 WebForml 的 设计 界面 复制 到 本 网 页 中 。 

@ 双击 Button1, 进 入 程序 代码 编辑 窗口 ,在 Button1_Click 事件 过 程 中 输入 “Labell. 
Text 二 "您 单 击 了 按钮 ";” 一 行 。 

@ 单 击 。 源 选项 卡 , 可 以 看 到 WebForm2 的 源 视图 代码 如 下 : 

<% @ Page Language = "C#" %> 

<!DOCTYPE html > 

< script runat = "server"> 

protected void Buttonl _Click(object sender, EventArgs e) 
. Labell.Text = "您 单 击 了 按钮 "; 
es 


<html xmlns = "http://waw.w3.org/1999/xhtml"> 
< head runat = "server"> 
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<meta http - equiv = "Content - Type" content = "text/html; charset = utf — 8"/> 


<title ></title> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
我 的 第 一 个 ASP .NET 网 页 <br /> 
<asp:Button ID = "Buttonl" runat = "server" Font ~ Bold = "True" Font - Names = "黑体 " 
Font - Size = "Small" OnClick = "Buttonl_Click" Text = " 单 击 " /> 
<br /> 
<asp:Label ID= "Labell" runat = "server" Font - Bold= "False" Font - Names = "楷体 " 
Font — Size = "Small"></asp:Label > 
</div> 
</form> 
</body> 
</html > 


@ 在 浏览 器 中 预览 该 网 页 ,其 操作 与 WebForml 网 页 完全 相同 。 

说 明 : 在 解决 方案 资源 管理 器 中 可 以 看 到 WebForm2 网 页 对 应 的 只 有 一 个 文件 , 即 
WebForm2. aspx。 

通常 , 单 文件 页 模型 适用 于 特定 的 网 页 ,在 这 些 网 页 中 ,代码 (编程 逻辑 ) 主 要 由 网 页 中 控 
件 的 事件 处 理 程序 组 成 。 

单 文件 页 模型 的 优点 : 在 没有 太 多 代码 的 网 页 中 ,可 以 方便 地 将 代码 和 标记 保留 在 同一 
个 文件 中 ; 因为 只 有 一 个 文件 ,所 以 使 用 单 文件 页 模型 编写 的 网 页 更 容易 部 署 或 发 送 给 其 他 
程序 员 ; 由 于 文件 之 间 没 有 相关 性 ,因此 更 容易 对 单 文件 网 页 进行 重 命名 ; 因为 网 页 包含 于 
单个 文件 中 , 故 在 源 代码 管理 系统 中 管理 文件 稍微 简单 一 些 。 


1.4.5 打开 一 个 网 站 


在 建立 一 个 网 站 并 保存 后 经 常 需要 打开 网 站 进行 修改 ,下 面 通过 一 个 示例 说 明 其 操作 
过 程 。 

【 例 1.3〗 打开 例 1. 1 建立 的 chl 网 站 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio。 

@ 选择 “文件 | 打开 | 网 站 ”命令 ,出 现 如 图 1. 19 所 示 的 “打开 网 站 ”对 话 框 ,其 中 左边 列表 
表示 打开 网 站 的 类 型 。 

。 文件 系统 : 从 磁盘 位 置 打 开 网 站 。 

。 本 地 IIS: 使 用 本 地 计算 机 上 的 IIS 打开 网 站 。 

。 FTP 站 点 : 从 FTP 位 置 打开 网 站 。 

。 远程 站 点 : 打开 FrontPage 网 站 。 

。 源 代码 管理 : 从 源 代码 管理 打开 网 站 。 

这 里 选择 “文件 系统 ”, 并 单 击 *D:\ASP.NET\ch1”, 然 后 单 击 “ 打 开 ” 按 钮 。 

@ 出 现 如 图 1. 20 所 示 的 Microsoft Visual Studio 对 话 框 ,提示 用 户 是 否 使 用 IIS 
Express, 因 为 在 Visual Studio 中 开发 网 站 时 需要 Web 服务 器 才能 测试 或 运行 它们 。Visual 
Studio 2010 之 前 的 版 本 内 置 了 Visual Studio Development Server( Visual Studio 开发 服务 
器 ) 用 于 测试 或 运行 网 站 , 自 Visual Studio 2010 版 本 开始 有 了 IIS Express。 在 Visual Studio 
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2012 中 可 以 使 用 Visual Studio 开发 服务 器 和 IIS Express 测试 或 运行 网 站 ,最 好 使 用 IIS 
Express, 因 为 Microsoft 公司 表示 以 后 的 Visual Studio 版 本 可 能 不 再 支持 Visual Studio 开发 
服务 器 。 


文件 系统 
选择 要 打开 的 文件 夫 (S)- 
EE] 
b 司 库 
”区 Administrator 
4 计算 机 
b 到 系统 (C3 
4 Ea 软件 (D3) 
， 国 2015 本 科 生 毕 Wi 计 
用 abc 
4 国 ASP.NET 
3 
证 
图 ch3 
， 国 ca 
， 国 ds 
， 国 ch6 
， 国 ch7 
国 chs 
， 略 ce 
， 国 chio 
” 帮 chll 
vv 加 chl2 
》 国 SMIS 
” 国 Student 
” 力 tmp 


HR uc 


文件 夫 (: 
DAASP.NET\ch1 


图 1.19 “打开 网 站 ”对 话 框 


这 里 单 击 “是 ”按钮 ,表示 使 用 IIS Express。 
@ 此 时 打开 chl 网 站 。 在 运行 网 页 时 , Windows 的 任务 栏 中 会 出 现 一 个 表示 IIS 
Express 的 小 图 标 , 如 图 1. 21 所 示 , 说 明 在 运行 网 页 时 自动 启动 了 IIS Express。 


Microsoft visualsudio 重生 


IIS Express 已 配置 为 向 “D:\WASP.NET\Vch1” 文 件 去 中 的 页 面 香 供 最 
务 。 是 否 要 打开 该 站 点 并 使 用 IIS Express 作为 眼 务 器 ? 迹 择 “是 " 可 
使 用 IIS Express , 选择 “ 否 ”可 打开 该 站 点 并 使 用 Visual Studio 
Development Server, 


ETD ET wm |] SD .8 


图 1.20 Microsoft Visual Studio 对 话 框 图 1.21 Windows 的 任务 栏 中 出 现 的 
JIS Express 的 小 图 标 
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如 果 建 立 的 网 站 已 默认 使 用 Visual Studio 开发 服务 器 ,现在 要 改 为 使 用 IIS Express, 其 
操作 是 在 解决 方案 资源 管理 器 中 右 击 网 站 名 (如 ch1), 在 出 现 的 快捷 菜单 中 选择 “使 用 IIS 
Express” 命 邻 。 

如 果 要 配置 Visual Studio 将 IIS Express 作为 默认 的 Web 服务 器 ,选择 “工具 | 选项 ” 命 
令 , 单 击 左边 列表 中 的 “项 目 和 解决 方案 | Web 项 目 ” 结 点 ,选中 “将 IIS Express 用 于 新 的 基于 
文件 的 网 站 和 项 目 ”, 单 击 “ 确 定 ” 按 钮 ,这 样 会 使 Visual Studio 对 新 创建 的 网 站 和 项 目 使 用 
IIS Express, 即 将 IIS Express 作为 默认 的 Web 服务 器 。 


1.4.6 ASP.NET 网 站 的 工作 原理 


前 面 创建 的 chl 网 站 相当 简单 ,但 是 让 WebForml 网 页 显示 在 浏览 器 中 却 没 有 那么 简 
单 。 在 浏览 器 能 够 显示 它 之 前 ,需要 一 个 Web 服务 器 对 它 进行 处 理 , 这 就 是 Visual Studio 自 
动 启动 IIS Express 来 处 理 网 页 请 求 的 原因 。 接 下 来 , 它 会 启动 默认 的 Web 浏览 器 并 定向 到 
Web 服务 器 的 地 址 “http://localhost:50922/WebForml. aspx”, 不 过 每 次 启动 Web 服务 器 
时 ,这 个 地 址 中 的 实际 端口 号 可 能 都 不 同 , 因 为 该 数字 是 Visual Studio 随机 选择 的 。 

用 户 要 意识 到 ,在 Visual Studio 中 创建 的 . aspx 文件 并 不 是 在 浏览 器 中 最 终 显示 的 文件 。 
在 Visual Studio 中 创建 一 个 网 页 时 就 向 它 添加 了 标记 ,网 页 中 的 标记 由 HTML、ASP.NET 
服务 器 控件 的 代码 组 成 。 

在 浏览 器 中 请 求 一 个 .aspx 网 页 时 ,Web 服务 器 就 会 处 理 这 个 网 页 ,执行 它 在 文件 中 找到 
的 所 有 服务 器 端 代码 ,并 有 效 地 将 ASP.NET 标记 转换 为 纯 HTML ,然后 发 送 给 显示 这 个 页 
面 的 浏览 器 。 

例如 在 运行 WebForml 网 页 时 ,在 图 1.18(a) 中 右 击 网 页 并 选择 “查看 源 ” 命 令 , 这 样 还 会 
打开 一 个 默认 的 文本 编辑 器 ,用 于 显示 该 页 面 的 HTML 代码 (服务 器 运行 WebForml 网 页 后 
发 送 给 客户 端的 代码 ) ,看 到 的 代码 如 下 : 


<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head> 
<meta http - equiv= "Content ~ Type" content = "text/html; charset = utf— 8" /> 
<title></title> 
</head> 
<body> 
< form method = "post" action = "WebForml.aspx" id= "forml"> 
<div class = "aspNetHidden"> 
< input type = "hidden" name ="__VIEWSTATE" id="_VIEWSTATE" 
value = "imqMDAqlsejePvD1BL9T5TOyYhCQymNxs2NfZ13wBV + gb99i11VMXUfIm1P63J 
dNRq0zNz + Js72sk/dYhiCwZHULrGv/f7dz6PjOoK66MRU = " /> 
</div> 
<div class = "aspNetHidden"> 
< input type = "hidden" name ="__VIEWSTATEGENERATOR" 
id="_VIEWSTATEGENERATOR" value = "C687F31A" /> 
< input type = "hidden" name ="__EVENTVALIDATION" id= " _EVENTVRLIDRTION" 
value = "wXde203FbKBkEXnyoST14XF9tOwzP7 + NZmC96FoKdxMqJ5tkBjR3XX5D4Rdqkz 
oO0xk44iBDgquovdgOR6IMRp7m1LnpkCNHG9 hEkmImPFOAalS4zLJ + MjZhrZrhfhxr2z" /> 
</div> 
<div> 
我 的 第 一 个 RSP .NET 网 页 


<br /> 
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< input type = "submit" name = "Button1"” value = " 单 击 " id= "Button1" 
style= "font -family: 黑 体 ;font size:Small;font - weight:bold;" /> 

<br /> 

<span id = "Labell”style = "font - family: 楷 体 ; 
font - size:Small; font — weight:normal;"></span> 

</div> 
</form> 
</body> 
</html > 


上 述 代 码 是 纯 HTML, 其 中 有 3 个 隐藏 域 ,name 为 ”VIEWSTATE” 是 一 个 隐藏 域 ,只 
有 form 表单 ( 窗 体 ) 标 识 runat 为 server 时 才 会 自动 生成 这 个 隐藏 域 。 当 请 求 某 个 网 页 时 ， 
ASP.NET 把 所 有 控件 的 状态 序列 化 成 一 个 字符 串 , 然 后 作为 网 页 的 隐藏 属性 送 到 客户 端 。 
当 客 户 端 把 网 页 回 传 时 ,ASP.NET 分 析 回 传 的 网 页 窗 体 属性 ,并 赋 给 控件 对 应 的 值 。 

name 为 "~_VIEWSTATEGENERATOR” 的 隐藏 域 用 于 在 ASP.NET 运行 时 帮助 确定 是 
回 传 到 相同 的 网 页 还 是 跨 页 。 

name 为 "~_EVENTVALIDATION” 的 隐藏 域 用 来 验证 事件 是 否 从 合法 的 网 页 发 送 , 它 
只 是 一 个 数字 签名 ,可 以 阻止 由 潜在 的 恶意 用 户 从 浏览 器 端 发 送 的 未 经 授权 的 请 求 。 

另外 ,head 元 素 中 的 meta 是 元 标记 ,其 中 包含 了 对 应 html 的 相关 信息 ,客户 端 浏览 器 或 
服务 器 端的 程序 会 根据 这 些 信息 进行 处 理 。 例 如 ,以 下 代码 表示 网 页 文字 编码 为 utf-8: 

<meta http - equiv = "Content - Type”" content = "text/html; charset = utf - 8" /> 

而 以 下 代码 表示 网 页 运行 时 每 5 秒 刷 新 一 次 : 

<meta http-equiv = "Refresh" content = "5" /> 


此 时 用 户 单 击 “ 单 击 " 按 钮 进入 图 1. 18(b) 所 示 的 浏览 器 界面 后 ,再 右 击 网 页 并 选择 “查看 
源 " 命 令 , 看 到 的 代码 如 下 : 


<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head> 
<meta http - equiv= "Content ~ TYpe"” content = "text/html;charset = utf— 8" /> 
<title></title> 
</head> 
<body> 
< form method= "post" action = "WebForml.aspx" id= "forml"> 

<div class = "aspNetHidden"> 

< input type = "hidden" name="__VIEWSTATE" id="__VIEWSTATE" 
value = "XgXAStCtATpFAwl1t3m6E5Xd8faw/Rax54pltnWYnztGiFwhrvxUEH3ralbcw 
obxNzKSM/CHVuX1YSRIUSczV + V5Yi58beIBCtDdkge8qtj8XFWynsDmOhcsUpy 
MsOL7HISUH738sK3hbBuOK9ZtvyQ == " /> 
</div> 
<div class = "aspNetHidden"> 
< input type = "hidden" name ="__VIEWSTATEGENERATOR" id="__VIEWSTATEGENERATOR" 
value = "C687F31A" /> 

< input type = "hidden" name = "_ EVENTVALIDATION" id="_EVENTVALIDATION" 
value = "EBWQqBOCiL2SJ27noUhUoUWx5mKL8394CXAV1oumldl]sjlIa4pF9D+ 76P1Ft1 
19Cxh84A5sCInMjT1Boe8CEb9I + gFZsDb9E + thbaprveBosrKW8vuf5JLbGFVLPVYuT"” /> 

</div> 

<div> 
我 的 第 一 个 ASP .NET 网 页 
<br /> 
< input type = "submit" name = "Button1" value = " 单 击 " id = "Button1" 
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style= "font - family: 黑 体 ;font- size:Smal1;font - weight:bold;" /> 
<br /> 
< span id = "Labell" style= "font family: 楷 体 ; 
font- size:Small;font - weight:normal;"> 您 单 击 了 按钮 </span > 
</div> 
</form> 
</body> 
</html > 


从 中 可 以 看 到 ,开发 人 员 设 计 好 一 个 ASP.NET 网 页 后 ,在 请 求 该 网 页 时 ,ASP.NET 执 
行 网 页 ,通过 ASP.NET 引擎 将 其 转换 为 纯 HTML, 图 1.22 所 示 的 是 上 述 WebForml 网 页 中 
命令 按钮 Buttonl 的 代码 转换 方式 。 


.aspx 网 页 代码 


<asp:Button ID="Buttonl" runat="server" Font-Bold="True" 
Font-Names=" 黑 体 " Font-Size="Small" OnClick="Buttonl_CLick” 
Text=" 单 击 " 户 


由 ASPNET 引 党 转换 


<input type="submit" name="Buttonl" value=" 单 击 " id="Buttonl" 


纯 HTML 代 码 


图 1.22 ASP.NET 进行 的 代码 转换 


本 章 只 是 介绍 开发 ASP.NET 网 站 的 基本 知识 ,相关 的 内 容 和 原理 将 在 后 面 分 章 循 序 渐 
进 地 讨论 。 


练习 题 1 


. 简 述 WWW 的 特点 。 

. 简 述 静态 网 页 和 动态 网 页 的 执行 过 程 ,说 明 两 者 的 异同 。 
. 简 述 .NET Framework 的 作用 。 

. 简 述 Visual Studio 2012 创建 网 站 的 过 程 。 

简 述 什么 是 ASP. NET。 

简 述 典型 的 ASP.NET Web 网 页 请 求 过 程 。 

. 简 述 什么 是 ASP.NET 网 页 文件 。 

. 简 述 ASP.NET 引擎 的 作用 。 

. 简 述 两 种 ASP.NET 网 页 代码 编写 模型 的 差别 。 

10. 简 述 . aspx 网 页 与 纯 HTML 代码 有 什么 不 同 。 


上 机 实验 题 1 


在 chl 网 站 中 添加 一 个 名 称 为 Expermentl 的 网 页 ,其 中 包含 一 个 命令 按钮 Buttonl 和 一 
个 标签 Labell , 当 用 户 单 击 Buttonl 时 ,在 Labell 中 显示 “上 机 实验 题 1”, 如 图 1. 23 所 示 ,并 


忆 oo 站 中 世情 性 
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查看 运行 时 的 客户 端 代码 。 
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图 1.23 上 机 实验 题 1 网 页 的 运行 结果 


ASP.NET 网 站 结构 第 2 章 


在 开发 的 ASP.NET 应 用 程序 中 最 多 的 是 ASP.NET 网 站 类 型 。 最 简单 
的 网 站 包含 一 个 目录 ,其 中 至 少 包含 一 个 . aspx 文件 (ASP.NET 网 页 ) 和 一 个 
配置 文件 。 本 章 介绍 ASP.NET 网 站 和 网 页 的 结构 。 

本 章 学 习 要 点 : 

回 掌握 ASP.NET 网 站 常见 的 文件 类 型 和 目录 类 型 。 

加 掌握 ASP.NET 网 页 的 结构 。 

回 掌 握 常 见 的 ASP.NET 页 面 指令 的 使 用 方法 。 

回 掌 握 ASP.NET 网 站 的 编译 过 程 。 

回 掌 握 ASP.NET 服务 器 控件 的 特点 和 HTML 服务 器 控件 的 使 用 。 


2.1 ASP.NET 网 站 的 基本 结构 


一 个 典型 的 ASP.NET 网 站 通常 由 多 个 网 页 组 成 ,每 个 网 页 将 共享 许多 通 
用 的 资源 和 配置 设置 。 


2.1.1 网 站 文件 类 型 


从 文件 组 成 来 看 ,网 站 由 多 个 文件 组 成 ,包括 Web 网 页 .配置 文件 和 数据 
库 文件 等 ,最 常见 的 文件 类 型 如 下 。 

。 x* .aspx: ASP.NET 网 页 文件 ,包含 用 户 界 面 的 代码 。 

。 * .cs: 采用 代码 隐藏 页 模型 设计 网 页 时 的 代码 隐藏 文件 。 如 果 选 择 
C# 作 为 开发 语言 , 则 产生 . cs 文件 。 

。 x ascx: 开发 人 员 自 己 设计 的 ASP.NET 用 户 控件 。 

。 Web. config: ASP.NET 应 用 程序 的 基于 XML 格式 的 配置 文件 , 包 
各 种 ASP. NET 功能 的 配置 信息 , 如 数据 库 连接 、 安 全 设置 ,状态 
理 等 。 

。 global. asax: 全 局 应 用 程序 文件 ,该 文件 驻 留 在 ASP.NET 网 站 的 根 目 
录 下 :4 

。 x*.asmx 文件 : 为 其 他 计算 机 提供 共享 应 用 程序 的 Web 服务 。 


含 
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。 * .skin 文件 : 外 观 文件 ,用 于 设置 主题 。 
® 关 。CSS 文件 : 样式 表 文 件 。 
。 * .master: 母 版 页 文件 。 


2.1.2 网 站 的 目录 结构 


每 个 网 站 都 有 一 个 目录 ,为 了 更 方便 管理 和 使 用 ,ASP.NET 保留 了 一 些 可 用 于 特定 内 容 
的 文件 和 目录 名 称 。 一 个 网 站 常用 的 目录 如 下 。 

。 App_Data 目录 : 用 于 存放 应 用 程序 使 用 的 数据 库 。 它 是 一 个 集中 存储 应 用 程序 所 用 
数据 库 的 地 方 。App_Data 目录 可 以 包含 SQL Server 数据 库 文件 (. mdf)、Access 数 
据 库 文件 (. mdb) 或 XML 文件 等 。 

。 App_Code 目录 : 用 于 存放 所 有 应 当 作 为 应 用 程序 的 一 部 分 动态 编译 的 类 文件 。 在 开 
发 网 站 时 ,对 App_Code 目录 的 更 改 会 导致 整个 应 用 程序 的 重新 编译 。 

。 Bin 目录 : 包含 应 用 程序 所 需 的 用 于 控件 .组 件 或 者 需要 引用 的 任何 其 他 代码 的 可 部 
署 程序 集 。 该 目录 中 存在 的 任何 . dll 文件 将 自动 地 链接 到 应 用 程序 。 

。 App_Themes 目录 : 用 于 存放 主题 文件 和 CSS 文件 等 。 

。 App_GlobalResources 目录 : 用 于 存放 系统 资源 文件 。 资 源 文件 是 一 些 字 符 串 表 , 当 
应 用 程序 需要 根据 某 些 事情 进行 修改 时 ,资源 文件 可 用 于 这 些 应 用 程序 的 数据 字典 。 
除了 字符 串 之 外 ,用 户 还 可 以 在 资源 文件 中 添加 图 像 和 其 他 文件 。 


2.1.3 .aspx 网 页 的 结构 


ASP.NET 页 面 的 结构 是 非常 模块 化 的 ,每 个 . aspx 网 页 文件 一 般 包 含 3 个 独立 的 部 分 ， 
即 页 面 指令 .代码 脚本 块 和 页 面 内 容 。 

1. 页 面 指令 

页 面 指令 设置 页 面 的 运行 环境 ,规定 ASP. NET 引擎 如 何 处 理 该 页 面 , 控 制 ASP.NET 页 
面 的 行为 ,一 个 页 面 可 以 包含 多 条 页 面 指令 。 

2. 代码 脚本 块 

代码 脚本 块 是 由 二 script runat= server 盖 二 /Script 二 标记 对 括 起 来 的 程序 代码 。 在 代码 
脚本 块 中 可 以 定义 页 面 的 全 局 变量 及 控件 事件 处 理 程序 等 ,这 些 程序 代码 要 先 编译 后 执行 。 

3. 页 面 内 容 

页 面 内 容 是 由 网 页 元 素 构成 的 ,常见 的 网 页 元 素 有 文本 、 图 像 .链接 .表格 .框架 和 表单 等 。 
在 设计 网 页 内 容 时 ,应 尽 可 能 做 到 条 理性 强 .操作 逻辑 清晰 和 用 户 体验 好 。 


2.2 ASP.NET 页 面 指令 


页 面 指令 用 来 定义 ASP.NET 网 页 分 析 器 和 编译 器 使 用 该 网 页 的 一 些 设置 。 这 些 指令 多 
许 用 户 为 特定 网 页 指定 页 面 属性 和 配置 信息 ,是 由 ASP.NET 用 作 处 理 页 面 的 指令 ,但 不 作为 
发 送 到 浏览 器 的 标记 的 一 部 分 呈现 。 当 使 用 这 类 指令 时 ,虽然 标准 的 做 法 是 将 指令 包括 在 文 
件 的 开头 ,但 是 它们 可 以 位 于 . aspx 或 . ascx 文件 中 的 任何 位 置 。 每 个 页 面 指令 都 可 以 包含 一 
个 或 多 个 特定 于 该 指令 的 属性 (与 值 成 对 出 现 ) ,下 面 介绍 常见 的 页 面 指令 。 
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1. @Page 指令 


该 指令 允许 开发 人 员 为 网 页 指定 多 个 配置 选项 ,并 且 该 指令 只 能 在 Web 窗 体 网 页 中 使 
用 。 每 个 .aspx 文件 只 能 包含 一 条 @ Page 指令 。 该 指令 可 以 指定 页 面 中 代码 的 服务 器 编程 
语言 、 页 面 是 将 服务 器 代码 直接 包含 在 其 中 ( 即 单 文件 页 面 ) 还 是 将 代码 包含 在 单独 的 类 文件 
中 ( 即 代码 隐藏 页 面 )、 调 试 和 跟踪 选项 、 页 面 是 否 为 某 母 版 页 的 内 容 页 等 。 

其 基本 格式 如 下 : 

<%@Page 属性 = " 值 " [属性 = " 值 ” …] %> 

其 中 使 用 的 主要 属性 及 其 说 明 如 表 2. 1 所 示 。 若 要 定义 @ Page 指令 的 多 个 属性 ,需要 使 
用 一 个 空格 分 隔 每 个 属性 / 值 对 。 对 于 特定 属性 ,不 要 在 该 属性 与 其 值 相 连 的 等 号 (一 ) 两 侧 加 
空格 。 


表 2.1 @Page 指令 的 属性 及 其 说 明 


属 性 说 明 
AutoEventWireup ”指示 页 面 的 事件 是 否 自动 绑 定 。 如 果 启 用 了 事件 自动 绑 定 , 则 为 True( 默 认 值 ) , 否 
则 为 False 
Buffer 确定 是 否 启用 了 HTTP 响应 缓冲 。 如 果 启 用 了 页 面 缓冲 , 则 为 True( 默 认 值 ), 和 否 
则 为 False 
ClassName 一 个 字符 串 ,指定 在 请 求 页 面 时 将 自动 进行 动态 编译 的 页 面 的 类 名 。 此 值 可 以 是 


任何 有 效 的 类 名 ,并且 可 以 包括 类 的 完整 命名 空间 (完全 限定 的 类 名 )。 如 果 未 指 
定 该 属性 的 值 , 则 已 编译 页 面 的 类 名 将 基于 页 面 的 文件 名 


CodeBehind 指定 包含 与 页 面 关 联 的 类 的 已 编译 文件 的 名 称 。 该 属性 不 能 在 运行 时 使 用 

CodeFile 指定 指向 页 面 引用 的 代码 隐藏 文件 的 路 径 

CodePage 指示 用 于 响应 的 编码 方案 的 值 ,该 值 是 一 个 用 作 编 码 方案 ID 的 整数 

Description 提供 该 页 面 的 文本 说 明 。ASP.NET 分 析 器 忽略 该 值 

ErrorPage 定义 在 出 现 未 处 理 页 面 异 常 时 用 于 重 定向 的 目标 URL 

Inherits 定义 供 页 面 继 承 的 代码 隐藏 类 。 它 与 CodeFile 属性 (包含 指向 代码 隐藏 类 的 源 文 
件 的 路 径 ) 一 起 使 用 

Language 指定 在 对 页 面 中 的 所 有 内 联 呈 现 和 代码 声明 块 进行 编译 时 使 用 的 语言 ,只 可 以 表 


示 任 何 .NET Framework 支持 的 语言 ,如 C# 
MasterPageFile 设置 内 容 页 面 的 母 版 页 面 或 嵌 套 母 版 页 面 的 路 径 ,支持 相对 路 径 和 绝对 路 径 


Title 指定 在 相应 的 HTML<title> 标 记 中 呈现 的 页 面 的 标题 :也 可 以 通过 编程 方式 将 
标题 作为 页 面 的 属性 来 访问 
Trace 指示 是 否 启用 跟踪 。 如 果 启 用 了 跟踪 , 则 为 True, 和 否则 为 False( 默 认 值 ) 


例如 ,第 1 章 例 1. 1 中 WebForml. aspx 网 页 文件 的 如 下 内 容 就 是 页 面 指令 ， 


< 外 @Page Language = "C 井 ”RutoEventWireup = "True" CodeFile = "WebForml.aspx.cs" 
Inherits = "WebForml" %> 


其 作用 是 指定 ASP. NET 网 页 编译 器 使 用 C# 作 为 网 页 的 服务 器 端 代 码 语言 ,自动 绑 定 
网 页 的 事件 ,该 网 页 代码 隐藏 文件 为 WebForml. aspx. cs, 供 页面 继 承 的 代码 隐藏 类 为 
WebForml 。 

2. @Import 指令 

该 指令 将 命名 空间 显 式 地 导入 网 页 中 ,使 所 导入 的 命名 空间 的 所 有 类 和 接口 可 用 于 该 网 
页 。 导 入 的 命名 空间 可 以 是 .NET Framework 类 库 或 用 户 定 义 的 命名 空间 的 一 部 分 。 其 基 
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本 格式 如 下 : 


<% @ Import namespace= " 值 ”%> 


@Import 指令 不 能 有 多 个 namespace 属性 。 若 要 导入 多 个 命名 空间 ,需要 使 用 多 条 
@Import 指令 来 实现 。 

例如 导入 .NET Framework 基 类 命名 空间 System. Net 和 用 户 定 义 的 命名 空间 UserNS， 
代码 如 下 : 


<% @Import namespace = "System. Net" $%> 
<$% @Import namespace = "UserNS" %>; 


实际 上 ,在 采用 Visual Studio 设计 ASP. NE 网 页 时 , 像 System、System. Web、System. 
Web. UI\ System. Web. UI. HtmlControls 和 System. Web. UI. WebControls 常用 的 命名 空间 
是 默认 导入 的 。 

3. @Control 指令 

@Control 指令 与 @Page 指令 基本 相似 ,在 . aspx 文件 中 包含 @Page 指令 ,而 在 . ascx 文 
件 中 不 包含 @Page 指令 ,该 文件 中 包含 了 @Control 指令 。 该 指令 只 能 用 于 用 户 控 件 中 。 用 
户 控件 在 带 有 ascx 扩展 名 的 文件 中 进行 定义 。 每 个 ascx 文件 只 能 包含 一 条 @Control 指令 。 
此 外 ,对 于 每 个 @Control 指令 ,只 允许 定义 一 个 Language 属性 ,因为 每 个 控件 只 能 使 用 一 种 
语言 。 

其 基本 格式 如 下 : 

<% @Control 属性 =" 值 " [局 性 =" 值 ”…] %> 


例如 ,在 网 站 中 新 添加 一 个 WebUserControl. ascx 用 户 控 件 ,其 中 @ Control 指令 的 默认 
代码 如 下 : 


<% @Control Language = "C#" AutoEventWireup = "True" CodeFile = "WebUserControl.ascx.cs" 
Inherits = "WebUserControl" %> 


4. @Master 指令 

该 指令 只 能 在 母 版 页 的 . master 文件 中 使 用 ,用 于 标识 ASP. NET 母 版 页 。 每 个 . master 
文件 只 能 包含 一 条 @ Master 指令 。 其 基本 格式 如 下 : 

<% @Master 属性 = " 值 " [属性 =" 值 ”…] %> 

例如 , 母 版 页 MasterPage. master 以 C# 作为 内 联 代码 语言 。 事 件 处 理 代 码 在 名 为 
MasterPage 的 分 部 类 中 定义 。 用 户 可 以 在 MasterPage. master. cs 文件 中 找到 MasterPage 类 
的 代码 ,对 应 的 设置 如 下 : 


< 外 @Master Language = "C#" CodeFile = "MasterPage. master.cs" 
Inherits = "MasterPage" $%> 


以 上 代码 用 到 了 @Master 指令 中 两 个 重要 的 属性 , 即 CodeFile 和 Inherits 属性 ,它们 的 
含义 与 @ Page 中 相似 ,只 是 改 为 针对 母 版 页 。 

5. @Implements 

该 指令 用 来 定义 要 在 网 页 或 用 户 控件 中 实现 的 接口 。 其 基本 格式 如 下 : 


<%@Implements interface= ”value ”第 > 


其 中 ,interface 属性 用 来 指定 要 在 网 页 或 用 户 控件 中 实现 的 接口 。 在 Web 窗 体 网 页 中 实 
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现 接口 时 ,开发 人 员 可 以 在 代码 声明 块 中 的 二 script 盖 元 素 的 开始 标记 和 结束 标记 之 间 创 建 其 
事件 ,方法 和 属性 ,但 不 能 使 用 该 指令 在 代码 隐藏 文件 中 实现 接口 。 

6. @Reference 

该 指令 以 声明 的 方式 将 网 页 .用户 控件 或 COM 控件 连接 到 目前 的 网 页 或 用 户 控件 。 使 
用 此 指令 可 以 动态 编译 与 生成 提供 程序 关联 的 页 面 、 用 户 控件 或 男 一 个 类 型 的 文件 ,并 将 其 连 
接 到 包含 @Reference 指令 的 当前 网 页 、 用 户 控 件 或 母 版 页 文件 ,这 样 就 可 以 从 当前 文件 内 部 
引用 外 部 编译 的 对 象 及 其 公共 成 员 。 

其 基本 格式 如 下 : 


<% @Reference page = " 值 ” control = " 值 " virtualPath= " 值 ” %> 


其 中 , page 属性 指定 外 部 网 页 , ASP .NET 动态 编译 该 网 页 并 将 它 连接 到 包含 
@Reference 指令 的 当前 文件 ; control 属性 指定 外 部 用 户 控 件 ,ASP.NET 动态 编译 该 控件 并 
将 它 连接 到 包含 @Reference 指令 的 当前 文件 ; virtualPath 属性 指定 引用 的 虚拟 路 径 , 只 要 生 
成 提供 程序 存在 ,可 以 是 任何 文件 类 型 ,例如 , 它 可 能 会 指向 母 版 页 。 

例如 ,使 用 @Reference 指令 连接 用 户 控件 MyControl. ascx, 对 应 的 代码 如 下 : 


< 外 @Reference Control = "MyControl. ascx" %> 


7. @OutpuiCache 

该 指令 用 于 以 声明 的 方式 控制 ASP. NET 网 页 或 网 页 中 包含 的 用 户 控件 的 输出 缓存 策略 。 
网 页 输出 缓存 就 是 在 内 存 中 存储 处 理 后 的 ASP. NET 网 页 内 容 。 这 一 机 制 允 许 ASP. NET 向 
客户 端 发 送 网 页 响应 ,而 不 必 再 次 经 过 网 页 处 理 生命 周期 。 

网 页 输出 缓存 对 于 那些 不 经 常 更 改 , 但 需要 大 量 处 理 才能 创建 的 网 页 特别 有 用 。 例 如 ,如 
果 创 建 大 通信 量 的 网 页 来 显示 不 需要 频繁 更 新 的 数据 ,网 页 输出 缓存 则 可 以 极 大 地 提高 该 网 
页 的 性 能 。 用 户 可 以 分 别 为 每 个 网 页 配置 网 页 缓存 ,也 可 以 在 Web. config 文件 中 创建 缓存 配 
置 文件 。 利 用 缓存 配置 文件 ,只 定义 一 次 缓存 设置 就 可 以 在 多 个 页 面 中 使 用 这 些 设置 。 

设置 网 页 输出 缓存 的 基本 格式 如 下 : 

< 外 @OutputCache 属性 = " 值 " [属性 =" 值 ”…] %> 

例如 ,设置 网 页 或 用 户 控件 进行 输出 缓存 的 持续 时 间 为 100 秒 ,代码 如 下 : 


<% @OutputCache Duration = "100" VaryByParam = "none" %> 


其 中 ,Duration 属性 设置 网 页 或 用 户 控件 进行 缓存 的 时 间 ( 以 秒 计 ), VaryByParam 属性 
是 以 分 号 分 隔 的 字符 串 列 表 , 用 于 使 输出 缓存 发 生变 化 ,none 表示 无 变化 。 

8. @Assembly 

该 指令 用 于 在 编译 时 将 程序 集 连接 到 当前 页 面 , 这 使 得 开发 人 员 可 以 使 用 程序 集 公 开 的 
所 有 类 和 方法 等 。 其 使 用 格式 有 如 下 两 种 : 

<% @Assembly name= "assemblyname" $%> 

<% @Assembly src = "pathname" %> 

其 中 ,name 指定 编译 页 面 时 要 连接 的 程序 集 ,src 指定 要 动态 编译 并 连接 到 当前 页 面 的 源 
文件 的 路 径 。 

必须 在 @Assembly 指令 中 包含 name 或 src 属性 ,但 不 能 在 同一 个 指令 中 包含 两 者 。 如 
果 需 要 同时 使 用 这 两 个 属性 , 则 必须 在 文件 中 包含 多 个 @ Assembly 指令 。 在 连接 Web 应 用 
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程序 的 Bin 目录 中 的 程序 集 时 ,将 自动 连接 到 该 应 用 程序 中 的 ASP.NET 文件 ,这 样 的 程序 集 
不 需要 @Assembly 指令 。 
例如 ,以 下 代码 使 用 @Assembly 指令 连接 到 用 户 定义 的 程序 集 myassembly: 


<% @Assembly name = "myassembly" $%> 
以 下 代码 使 用 @Assembly 指令 连接 到 VB 源 文件 mysource. vb: 


<% @Assembly src = "mysource. vb" %> 


2.3 代码 脚本 块 和 ASP.NET 网 站 编译 


2.3.1 代码 脚本 块 
代码 脚本 块 也 称 为 代码 声明 块 , 它 嵌 入 在 ASP. NET 应 用 程序 文件 的 二 script 二 块 中 。 


图 2. 1 所 示 的 是 脚本 块 的 分 类 。 
脚本 块 


服务 器 端 脚本 客户 端 脚本 


Casa 


— [ea] 
| 


图 2.1 脚本 块 的 分 类 


1. 客户 端 脚 本 

作为 页 面 的 一 部 分 的 客户 端 脚 本 , 当 用 户 请 求 页 面 时 ,将 这 些 脚 本 直接 发 送 至 客户 端 浏览 
器 ,由 浏览 器 执行 。 客 户 端 脚本 通常 用 JavaScript 或 VBScript 语言 编写 。 客 户 端 脚 本 可 以 完 
成 如 下 功能 : 

@ 在 将 某 个 页 面 加 载 至 浏览 器 中 时 ,改变 此 页 面 的 外 观 。 

@ 验证 用 户 在 窗 体 中 输入 的 数据 ,将 通过 验证 的 数据 发 送 至 服务 器 。 

@ 当 触 发 按钮 的 单 击 事件 时 ,在 浏览 器 中 显示 相关 信息 。 

例如 ,采用 JavaScript 编写 客户 端 脚本 代码 的 一 般 格式 如 下 : 

< script type = "text/javascript"> 

javascript 脚本 代码 

</script> 

需要 注意 的 是 ,服务 器 并 不 会 执行 这 些 客户 端 脚本 代码 ,而 是 直接 发 送 给 客户 端 浏览 器 ， 
它们 是 在 客户 端 浏览 器 中 执行 的 。 

2. 服务 器 端 脚本 

服务 器 脚本 也 是 页 面 的 一 部 分 ,但 它 不 发 送 至 浏览 器 ,而 是 在 请 求 页 面 之 后 和 在 回 送 至 浏 
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览 器 之 前 由 服务 器 处 理 。 服 务 器 端 代码 声明 块 必须 具有 runat 一 "server "属性 。 
服务 器 脚本 的 基本 格式 如 下 : 
< script runat = "server" language = "codelanguage" src = "pathname"> 
代码 部 分 
</script> 
对 其 中 各 个 属性 的 说 明 如 下 。 
。 language: 指定 用 于 代码 脚本 块 的 语言 。 该 值 可 以 表示 任何 与 .NET Framework 兼容 
的 语言 。 如 果 未 指定 任何 语言 ,该 值 默认 为 @Page 或 @Control 指令 中 指定 的 语言 。 
在 ASP.NET 网 页 或 用 户 控件 中 只 能 使 用 一 种 语言 。 如 果 在 多 处 指定 了 语言 (这 是 不 
必要 的 ), 例 如 在 代码 声明 块 的 开始 标记 和 @Page 或 @Control 指令 中 指定 了 语言 , 则 
这 些 语言 必须 匹配 。 当 然 也 可 以 使 用 type 属性 代替 language 属性 ,例如 ,language 一 
"javascript" 和 type 一 "textV/javascript" 的 作用 相同 。 
。 runat: 通常 设置 为 runat 一 "server", 它 指定 script 块 中 包含 的 代码 在 服务 器 而 不 是 客 
户 端 上 运行 。 此 属性 对 于 服务 器 端 代码 块 是 必需 的 。 
。 src: 指定 要 加 载 的 外 部 脚本 文件 的 路 径 和 文件 名 。 当 使 用 该 属性 时 ,将 忽略 声明 块 中 
的 任何 其 他 代码 。 
ASP. NET 提供 了 代码 隐藏 页 模型 和 单 文件 页 模型 两 种 代码 编写 模型 ,在 第 1 章 中 例 1.2 
采用 单 文件 页 模型 ,其 代码 脚本 块 如 下 : 


< script runat = "server"> 

protected void Buttonl_Click(object sender, EventArgs e) 

{ 

Labell.Text = "您 单 击 了 按钮 "; 

} 
</script> 
其 language 是 该 网 页 中 @ Page 页 面 指令 设置 的 C# 语 言 , 所 定义 的 Button1_Click 事件 

处 理 过 程 与 Buttonl 命令 按钮 的 OnClick 属性 关联 : 


<asp:Button ID = "Buttonl" runat = "server" Font ~ Bold= "True" Font - Names = "黑体 " 
Font - Size = "Small" OnClick = "Buttonl_Click" Text = " 单 击 " /> 

在 运行 该 网 页 时 ,用 户 单 击 Button1, 则 执行 Button1_Click 事件 处 理 过 程 。 

与 之 功能 等 价 的 例 1. 1 采用 代码 隐藏 页 模型 ,其 中 WebForml. aspx 文件 没有 直接 包含 
代码 脚本 块 ,只 不 过 将 相关 的 事件 处 理 过 程 放 在 另 一 个 文件 ( 即 WebForml. aspx. cs) 中 ,通过 
@ Page 页 面 指令 的 属性 设置 ( 即 CodeFile 二 "WebForml. aspx. cs") 建 立 关联 ,所 以 两 种 代码 
编写 模型 本 质 上 没有 差别 , 且 代 码 隐藏 页 模型 更 加 方便 。 

本 书 采用 C# 作 为 代码 语言 ,将 在 第 4 章 介 绍 C# 语 言 基 础 。 


2.3.2 ASP.NET 网 站 的 编译 和 预 编译 


为 了 使 用 应 用 程序 代码 为 用 户 提 出 的 请 求 提供 服务 ,ASP.NET 必须 首先 将 代码 编译 成 
一 个 或 多 个 程序 集 。 程 序 集 是 文件 扩展 名 为 dll 的 文件 ,dll 文件 在 服务 器 上 执行 ,并 动态 生成 
网 页 的 HTML 输出 。 用 户 可 以 采用 多 种 不 同 的 兼容 语言 来 编写 ASP.NET 代码 。 在 编译 代 
码 时 会 将 程序 代码 翻译 成 中 间 语 言 代 码 , 在 运行 时 .NET Framework 会 将 中 间 语 言 代 码 翻 译 
成 CPU 特定 的 指令 ,以 便 计算 机 上 的 处 理 器 运行 应 用 程序 。 
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在 编译 给 定 的 ASP.NET 应 用 程序 文件 时 ,嵌入 的 代码 块 将 随 与 给 定 的 ASP.NET 文件 
类 型 关联 的 特定 对 象 一 起 编译 。 例 如 编译 网 页 时 ,任何 嵌入 的 代码 声明 块 将 随 网 页 类 一 起 编 
译 到 服务 器 上 的 单个 网 页 对 象 中 。 

编译 应 用 程序 代码 的 好 处 : 提高 执行 速度 ; 编译 后 的 代码 要 比 非 编 译 的 源 代码 更 难 进行 
反 向 工程 处 理 , 提 供 了 安全 性 ; 可 以 消除 代码 中 的 许多 错误 ,提高 了 代码 的 稳定 性 。 

在 默认 情况 下 , 当 用 户 首次 请 求 资源 (如 网 站 的 一 个 网 页 ) 时 将 动态 编译 ASP. NET 网 页 
和 代码 文件 , 称 为 自动 编译 ,产生 编译 后 的 . dll 文件 ,实例 化 该 . dll 并 处 理 ( 响 应 用 户 首次 请 
求 )。 第 1 次 编译 网 页 和 代码 文件 之 后 ,会 缓存 编译 后 的 资源 。 当 用 户 第 2 次 请 求 时 (假设 资 
源 没有 发 送 变 化 ) ,没有 再 为 第 2 次 和 以 后 的 请 求 重复 上 述 整个 过 程 ,该 请 求 只 是 实例 化 已 创 
建 的. dl ,该 . dll 将 响应 发 送 给 请 求 者 ,这 样 将 极 大 地 提高 随后 对 同一 页 提出 的 请 求 的 效率 。 
用 户 首次 请 求 和 以 后 请 求 网 页 的 处 理 过 程 如 图 2. 2 所 示 。 


首次 请 求 
第 2 次 请 求 滔 
实例 化 第 2 个 请 求 的 页 | 编译 
面 类 


响应 Ce Ee 


图 2.2 用 户 首次 请 求 和 以 后 请 求 网 页 的 处 理 过 程 


实际 上 ,ASP. NET 在 将 整个 网 站 提供 给 用 户 之 前 可 以 预 编译 该 网 站 ,这 样 做 有 很 多 
好 处 ， 
。 可 以 加 快 用 户 的 响应 时 间 , 因 为 网 页 和 代码 文件 在 第 1 次 被 请 求 时 无 须 编译 。 这 对 于 
经 常 更 新 的 大 型 网 站 尤其 有 用 。 
。 可 以 在 用 户 看 到 网 站 之 前 识别 编译 时 错误 。 
。 可 以 创建 网 站 的 已 编译 版 本 ,并 将 该 版 本 部 署 到 成 品 服务 器 ,而 无 须 使 用 源 代码 。 
预 编 译 网 站 可 以 在 命令 行 上 使 用 Aspnet_compiler. exe 工具 实现 ,ASP.NET 提供 了 两 个 
预 编译 站 点 选项 。 
。 预 编译 现 有 网 站 : 如 果 和 希望 提高 现 有 网 站 的 性 能 并 对 网 站 执行 错误 检查 ,那么 此 选项 
十 分 有 用 。 
。 针对 部 署 预 编译 网 站 : 此 选项 将 创建 一 个 特殊 的 输出 ,可 以 将 该 输出 部 署 到 成 品 服 
务 器 。 


2.4 页 面 内 容 设 计 


页 面 内 容 设计 就 是 通过 各 种 各 样 的 HTML 标记 对 页 面 上 的 文字 、 图 片 、 表 格 、 声 音 等 元 
素 进行 描述 (例如 字体 .颜色 .大 小 ) ,而 浏览 器 则 对 这 些 标记 进行 解释 并 生成 页 面 ,于 是 就 得 到 
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可 以 看 到 的 画面 。 在 采用 Visual Studio 设计 ASP.NET 网 页 时 ,表示 页 面 的 可 视 元 素 有 静态 
元 素 和 服务 器 控件 。 


2.4.1 网 页 静态 元 素 设计 


所 谓 网 页 静态 元 素 设计 ,就 是 直接 采用 HTML 元 素 进行 网 页 设计 ,共有 两 种 方式 , 即 直 
接 用 HTML 十 CSS 和 采用 HTML 控件 设计 。 前 一 种 方式 将 在 第 3 章 详 细 介 绍 , 这 里 简要 介 
绍 后 一 种 方式 。 

Visual Studio 的 工具 箱 中 提供 了 HTML 控件 组 ,如 图 2. 3 所 示 , 其 中 的 控件 都 是 客户 端 
控件 。 在 设计 网 页 时 ,可 以 将 这 些 HTML 控件 直接 拖 放 到 网 页 中 进行 可 视 化 设计 。 

说 明 : 控件 是 一 种 类 , 绝 大 多 数控 件 都 具有 可 视 的 界面 ,能 [I | 
够 在 程序 运行 中 显示 其 外 观 。 利 用 控件 进行 可 视 化 设计 既 直 观 ”搜索 TR 箱 P- 
又 方便 ,可 以 实现 所 见 即 所 得 的 效果 。 程 序 设计 的 主要 内 容 是 “和 


人 
选择 和 设置 控件 及 对 控件 的 事件 编写 处 理 代码 。 加 Ey 
在 客户 端 脚本 代码 设计 中 常用 的 有 Document 对 象 和 只 Input(submid 
Element 对 象 等 ,有 关 更 多 的 内 容 , 读 者 可 以 参考 JavaScript 。 目 ， 人 
教程 。 回 Input (Password) 
每 个 载 入 浏览 器 的 HTML 文档 都 会 成 为 Document 对 象 。 四 ret 
Document 对 象 可 以 从 脚本 中 对 HTML 页 面 中 的 所 有 元 素 进 。 加 mpatiaden 
行 访问 ,其 常用 的 方法 如 下 。 人 
。 close() : 关闭 用 document. open() 方 法 打开 的 输出 流 ， 中 ee 
并 显示 选 定 的 数据 。 一 ”Horizontal Rule 
。 getElementById(): 返回 对 拥有 指定 ID 的 第 一 个 对 象 ”时 噬 
的 引用 。 图 2.3 HTML 控件 
。 getElementsByName(): 返回 带 有 指定 名 称 的 对 象 
集合 。 


。 getElementsByTagName(): 返回 带 有 指定 标签 名 的 对 象 集合 。 
。 open(): 打开 一 个 流 ,以 收集 来 自任 何 document. write() 或 document. writeln() 方 法 
的 输出 。 
。 write(); 向 文档 写 HTML 表达 式 或 JavaScript 代码 。 
Element 对 象 表示 XML 文档 中 的 元 素 , 元 素 可 包含 属性 、 其 他 元 素 或 文本 。 如 果 元 素 含 
有 文本 , 则 在 文本 结 点 中 表示 该 文本 。 其 中 ,textContent 属性 用 于 设置 或 返回 元 素 及 其 后 的 
文本 内 容 。 例 如 ,以 下 代码 用 于 获取 网 页 中 Labell 控件 的 文本 值 : 


document. getElementById( "Label1"). textContent 


下 面 讨论 一 个 客户 端 脚本 代码 设计 的 示例 ,说 明 网 页 静态 元 素 的 设计 方法 。 

【 例 2.1】 在 D 盘 ASP.NET 目录 中 建立 一 个 ch2 的 子 目录 ,将 其 作为 网 站 目录 ,然后 创 
建 一 个 WebForml. html 网 页 ,其 功能 是 说 明 HTML 控件 的 应 用 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012。 

@ 选择 “文件 | 新 建 | 网 站 ”命令 ,出 现 “ 新 建 网 站 ”对 话 框 ,然后 选择 “ASP.NET 空 网 站 ” 
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模板 ,选择 "Web 位置” 为 “文件 系统 ”, 单 击 “ 浏 览 ” 按 钮 ,选择 *D:\ASP.NET\ch2” 目 录 , 单 击 
“确定 ”按钮 ,创建 一 个 空 的 网 站 ch2。 

@ 选择 “网 站 | 添加 新 项 "命令, 出现“ 添加 新 项 -ch2” 对 话 框 ,在 中 间 列 表 中 选择 “Web 窗 
体 ”, 将 文件 名 称 改 为 WebForml. aspx, 去掉 “将 代码 放 在 单独 的 文件 中 ” 复 选 框 的 默认 色 选 
(创建 单 文件 页 模型 的 网 页 ) , 单 击 “ 添 加 ”按钮 。 

@ 进入 网 页 的 设计 视图 ,在 二 body 二 的 第 1 行 输 入 “学 习 使 用 HTML 控件 (客户 端 脚本 
设计 )”。 在 第 3 行 输入 * 输 入: ”, 再 从 工具 箱 的 HTML 控件 中 拖 放 一 个 回 Input (exy 控件 (ID 
为 Text1)。 在 第 5 行 中 拖 放 一 个 外 Input(Button) 控件 (ID 为 Button1), 进 入 属性 窗口 ,将 其 
value 设置 为 “ 单 击 ”。 在 第 7 行 输入 “字符 个 数 :”, 再 从 工具 箱 的 HTML 控件 中 拖 放 一 个 
国 Input (rex 控件 (ID 为 Text2)。 

选择 菜单 栏 的 “格式 ”中 的 站 部 硒 旧 -命令 对 网 页 中 的 各 个 元 素 进 行 字体 和 颜色 设计 ， 
例如 设计 Buttonl 的 字体 ,对 话 框 如 图 2. 4 所 示 。 该 网 页 的 最 终 设计 界面 如 图 2.5 所 示 。 


大 小 2) 
wedim (4 pt) 


We ee = 
-a 学 习 使 用 HTML 控 件 ( 客 户 正 脚本 设计 ) | 


国 同 除 续 z) | | 
国 上 划 线 @) | 
国内 和 中 固 胸 芋 输入 : | 
|[ 单 击 
这 儿 个 杀 :. aa | 


4 
设计 |a 折 分 |。 源 | [dw <spanauto-stylel> 上 


图 2.4 设计 Buttonl 的 字体 的 对 话 框 图 2.5 WebForml. aspx 网 页 的 设计 界面 


@ 进入 源 视图 ,修改 代码 如 下 (其 中 粗 体 是 新 增 部 分 ,其 余部 分 是 系统 自动 生成 的 ， 
Visual Studio 会 将 开发 人 员 的 可 视 化 设计 尽 可 能 地 转换 为 样式 ,有 关 样 式 内 容 将 在 第 3 章 
介绍 ) : 


< 第 @ Page Language= "C#" %> 
<!DOCTYPE html > 
< script type = "text/javascript"> 
function count() { 
document. getElementById(" Text2" ).value = 
document .getElementById("Text1" ). value. length; ; 

} 
</script > 
<html xmlns = "http://www.w3.org/1999/xhtm]l"> 

< head runat = "server"> 
<meta http - equiv= "Content ~ Type”" content = "text/htm1; charset = utf— 8"/> 
<title></title> 


< style type = "text/css"> 
.auto— stylel 
{ font- family: 楷体 ; font - weight: bold; 
font — size: medium; color: 提 0000FF; 
} 
井 Buttonl 
{ color: 提 FF0000; font— size: medium; 
font - weight: 700; font -family: 黑体 ; 
} 
提 Textl { width: 205px; } 
提 Text2 { width: 58px; } 
</style> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
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<span class = "auto stylel"> 学 习 使 用 HTML 控件 (客户 端 脚本 设计 )</span> 


<br /><br /> 


< span class = "auto - stylel"> 输 入 : </span>< input id = "Text1" type = "text" /> 


<br /><br /> 


< input id = "Buttonl" type = "button" value = " 单 击 ” onclick = "count()"/><br /> 


<br /> 


< span class = "auto - stylel"> 字 符 个 数 : </span >< input id = "Text2" type= "text" /> 


</div> 
</form> 
</body > 
</html > 
@ 单 击 工具 栏 中 的 > Imtemet Explorer 按钮 运行 本 网 页 ， 
在 文本 框 Textl 中 输入 “China”, 然 后 单 击 “ 单 击 ” 按 钮 ,得 
到 的 结果 如 图 2.6 所 示 。 
本 例 的 几 点 说 明 如 下 : 
@ JavaScript 脚本 代码 是 客户 端 代码 ,服务 器 直接 将 
其 发 送 到 客户 端 , 它 是 在 客户 端 浏览 器 中 运行 的 ,以 下 操 
作 可 以 验证 这 一 点 。 在 图 2. 6 所 示 的 浏览 器 界面 中 右 击 
网 页 并 选择 “查看 源 ” 命 令 , 可 以 看 到 服务 器 发 送 给 客户 
端的 代码 如 下 : 
<!DOCTYPE html > 
< script type = "text/javascript"> 
function count() { 
forml. Text2.value = forml.Textl.value. length; 
} 


</script> 
<html xmlns = "http://www.w3.org/1999/xhtml"> 


(OB eetonsi po] A 


情 localhost x 
学 习 使 用 HTML 控 件 (客户 英 脚 本 设计 ) 
| 输入 : [China 


图 2.6 WebForml.aspx 网 页 的 
执行 界面 


<head>< meta http— equiv = "Content ~ TYpe”content = "text/html; charset = utf - 8" /> 


<title></title> 
< style type= "text/css"> 
.auto— stylel { 
font - family: 楷体 ; font - weight: bold; 
font — size: medium; color: 提 0000FF; 
} 
井 Buttonl { 
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color: #FF0000; font— size: medium; 
font - weight: 700; font - family: 黑体 ; 
+ 
提 Textl { width: 205px; } 
提 Text2 { width: 58px; } 
</style> 
</head> 
<body> 
< form method = "post" action = "WebForml.aspx" id= "forml"> 
<div class = "aspNetHidden"> 
< input type = "hidden" name ="_ VIEWSTATE" id="_VIEWSTATE" 
value = "t5NTAYI78/FOXeVEF2mIPXNW2InWdTrF4sUh2BOH8Zp63V63qzJUDnW + 
s5JQJvgTH6rbagzhB1 + 1D99xcwfHLV2WV7VUOM9T361uVV1zrIsk =" /> 
</div> 
<div class = "aspNetHidden"> 
< input type = "hidden" name ="__VIEWSTATEGENERATOR" 
id="_VIEWSTATEGENERATOR" value = "C687F31A" /> 
</div> 
<div> 
< span class = "auto - stylel"> 学 习 使 用 HTML 控件 (客户 端 脚本 设计 )</span > 
<br /><br /> 
< span class = "auto - stylel"> 输 入 : </span>< input id = "Textl" type= "text" /> 
<br /><br /> 
< input id= "Button1" type = "button" value = " 单 击 ”onclick = "count()"/> 
<br /><br /> 
< span class = "auto - stylel"> 字 符 个 数 : </span >< input id= "Text2" type= "text" /> 
</div> 
</form> 
</body> 
</html > 


@ 如 果 在 一 script 二 中 添加 runat 一 "server" ,就 会 变 成 服务 器 脚本 ,服务 器 脚本 是 在 服务 
器 端 运行 的 ,而 Text2 等 HTML 元 素 是 在 客户 端 浏 览 器 中 呈现 的 ,服务 器 并 不 处 理 Text2, 所 
以 改 为 服务 器 脚本 后 出 现 Text2 没有 定义 的 错误 消息 。 

@ 本 例 中 Textl .Text2 和 Buttonl 等 HTML 控件 的 代码 中 都 没有 runat 一 "server" , 表 
示 它 们 都 是 客户 端 元 素 。 如 果 将 本 例 的 二 script 二 改 为 如 下 代码 ,同样 会 出 现 Text2 等 没有 定 
义 的 错误 : 

<script> 


protected void Buttonl_ServerClick(object sender, EventArgs e) 


|! 
Text2. Value = Textl. Value. Length; 


} 
</script> 


2.4.2 ASP.NET 服务 器 控件 


为 了 使 服务 器 将 程序 代码 转换 为 客户 端 浏 览 器 能 够 认识 的 代码 ,需要 使 用 ASP.NET 服 
务 器 控件 。 所 有 服务 器 控件 都 要 添加 runat 二 "server" 属 性 ,在 ASP.NET 引擎 处 理 时 ,会 将 
它们 转换 为 相应 的 客户 端 HTML 元 素 。ASP.NET 服务 器 控件 分 为 3 类 , 即 HTML 服务 器 
控件 .Web 标准 服务 器 控件 和 其 他 服务 器 控件 。 
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1. HTML 服务 器 控件 
默认 情况 下 ,ASP.NET 文件 中 的 HTML 元 素 作为 文本 进行 处 理 ,并 且 不 能 在 服务 器 端 
代码 中 引用 这 些 元 素 。 若 要 使 这 些 元 素 能 以 编程 方式 进行 访问 ,可 以 通过 添加 runat 一 


"server" 


属性 表明 应 将 HTML 元 素 作 为 服务 器 控件 进行 处 理 , 还 需要 设置 元 素 的 ID 属性 ,使 


得 可 以 通过 编程 方式 引用 控件 。 
HTML 控件 转换 为 服务 器 控件 后 ,控件 的 事件 在 服务 器 中 处 理 , 对 应 的 事件 名 称 也 会 发 


生变 化 。 
onClick 


例如 ,命令 按钮 Button 包含 onServerClick 属性 ,而 不 是 常规 HTML 中 使 用 的 
属性 ,就 是 告诉 服务 器 当 命 令 按 钮 的 单 击 事件 发 生 时 应 调用 的 事件 处 理 过 程 是 “命令 


按钮 id_ServerClick”。 若 希望 控件 在 客户 端 处 理事 件 , 则 应 使 用 传统 的 onClick 属性 。 这 时 
必须 提供 客户 端 脚本 来 处 理事 件 , 系 统 会 首先 执行 客户 端 代码 ,然后 再 执行 服务 器 代码 。 


【 例 
解 : 


@ 打开 ch2 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 
“添加 新 项 -ch2” 对 话 框 ,然后 在 中 间 列 表 中 选择 Web 窗 


2.2】 在 ch2 网 站 中 设计 一 个 网 页 WebForm2 ,说明 HTML 服务 器 控件 的 应 用 。 
其 步骤 如 下 。 


中 

体 ”, 将 文件 名 称 改 为 WebForm2. aspx, 去 掉 "将 代码 放 [一 一 | | 
在 单独 的 文件 中 ” 复 选 框 的 默认 色 选 (创建 单 文 件 页 模型 ll | 
的 网 页 ), 单 击 "添加 ”按钮 。 0 

@ 该 网 页 的 设计 界面 如 图 2.7 所 示 , 其 中 包含 两 个 加 
input(Text)HTML 控件 (id 为 TextBoxl 和 TextBox2) “ES 


和 一 个 input(Button) HTML 控件 Button1l 。 


5 设计 ] 日 折 分 |。 源 | |4] <spanauto-sty|>] 


@ 进入 源 视图 ,设计 对 应 的 代码 (其 中 粗 体 是 增加 。 图 2.7 WebForm2.aspx 网 页 的 


部 分 ) : 


设计 界面 


<% @ Page Language = "C#" %> 
<!DOCTYPE html > 
< Script runat = "server"> 


Protected void Buttonl ServerClick(object sender, EventArgs e) 
{ 

Text2.Value = "您 输入 的 是 : ”+ Textl1.Value; 
} 


</script> 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head runat = " server"> 


<meta http - equiv= "Content ~ Type" content = "text/html; charset = utf— 8"/> 
<title></title> 
< style type= "text/css"> 
.auto ~ stylel 
{ font- family: 楷体 ; font - weight: bold; 
font - size: medium; color: 间 0000FF; 
} 
提 Textl { width: 72px; } 
间 Buttonl 
{ color: 划 FF0000; font ~ size: medium; 
font - weight: 700; font - family: 黑体 ; 
} 
</style> 


</head> 
<body> 
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<form id= "forml" runat ="server"> 


<div> 


< span class = "auto stylel"> 学 习 使 用 HTML 服务 器 控件 </span> 


<br /><br /> 


< span class = "auto - stylel"> 输 入 : </span> 
< input id= "Text1" runat = " server" type = "text" /> 


<br /> <br 人 > 


< input id= "Buttonl" runat = "server” type = "button" value = " 单 击 " 
onServerClick = "Buttonl ServerClick" /> 


</div> 


<p><input id = "Text2" runat = "server" type = "text" /></p> 


</form> 
</body> 
</html > 


@ 单 击 工 具 栏 中 的 P Internet Explorer 按钮 运行 本 网 页 ,在 输入 文本 框 中 输入 "China”, 然 后 
单 击 “ 单 击 ” 按 钮 ,得 到 的 结果 如 图 2.8 所 示 。 从 中 可 以 看 到 , Buttonl _ServerClick 事件 过 程 


得 到 了 执行 。 


EX 


全 | 和 @ hapy/localhost5147. PD - © 
感 localhost x 


学 习 使 用 HTML 服 务 器 控件 


输入 : [China 
| 单 击 


您 输入 的 是 : China 


图 2.8 WebForm2. aspx 网 页 的 
执行 界面 


互 ,可 以 使 用 普通 的 HTML 元 素 。 
2. Web 标准 服务 器 控件 


实际 上 ,除了 可 以 将 HTML 控件 转换 为 HTML 服 
务 器 控件 之 外 , ASP . NET 还 提供 了 一 组 与 之 对 应 的 
HTML 服务 器 控件 ,它们 的 名 称 以 Html 开头 , 如 
HtmlInputButton 与 二 input type 一 "button" 二 对应， 
HtmlInputText 与 二 input type 一 "text" 之 对 应 ,而且 它 
们 的 对 象 模型 紧密 映射 到 相应 元 素 的 对 象 模型 ,并 自动 
维护 控件 状态 , 即 在 网 页 到 服务 器 的 往返 行程 中 ,将 自动 
对 用 户 在 这 些 HTML 服务 器 控件 中 输入 的 值 进 行 维 护 
并 发 送 回 浏览 器 。 

说 明 : 从 前 面 的 两 个 示例 可 以 看 出 ,在 开发 ASP . 
NET 应 用 程序 时 建议 使 用 服务 器 控件 , 如果 不 需要 交 


Web 服务 器 控件 比 HTML 服务 器 控件 具有 更 多 的 内 置 功能 。Web 服务 器 控件 不 仅 包括 
窗 体 控件 (例如 按钮 和 文本 框 ), 而 且 包括 特殊 用 途 的 控件 (例如 日 历 . 菜 单 和 树 视图 控件 )。 
Web 服务 器 控件 与 HTML 服务 器 控件 相 比 更 加 抽象 ,因为 其 对 象 模型 不 一 定 反映 HTML 请 
法 。 有 关 Web 服务 器 控件 的 使 用 将 在 第 6 章 介 绍 。 


3. 其 他 服务 器 控件 


其 他 服务 器 控件 主要 包含 以 下 控件 。 

。 验证 控件 : 包含 逻辑 以 允许 对 用 户 在 输入 控件 (例如 TextBox 控件 ) 中 输入 的 内 容 进 
行 验证 的 控件 。 验 证 控件 可 用 于 对 必 填 字段 进行 检查 ,对 照 字符 的 特定 值 或 模式 进行 
测试 ,验证 某 个 值 是 否 在 限定 范围 之 内 ,等 等 。 

。 用 户 控件 : 作为 ASP.NET 网 页 创建 的 控件 ,ASP.NET 用 户 控件 可 以 嵌入 其 他 ASP. 
NET 网 页 中 ,这 是 一 种 创建 工具 栏 和 其 他 可 重用 元 素 的 捷径 。 

。 登录 控件 : 提供 了 一 个 方便 的 方法 来 创建 ASP.NET 网 页 ,这 些 网 页 包含 用 于 用 户 登 
录 、 密 码 恢复 和 创建 新 用 户 的 控件 。 默 认 情 况 下 ,登录 控件 与 ASP.NET 成 员 资 格 集 
成 ,以 帮助 网 站 的 用 户 身份 验证 过 程 自动 化 。 
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在 后 面 的 章节 中 将 介绍 上 述 各 类 服务 器 控件 的 使 用 和 设计 方法 。 
练习 题 2 


. 简 述 ASP.NET 网 站 的 基本 文件 类 型 。 
简 述 ASP.NET 网 站 的 基本 目录 结构 。 
. 简 述 . aspx 网 页 的 基本 结构 。 
简 述 ASP. NET @ Page 指令 的 作用 。 
. 简 述 ASP. NET 客户 端 脚本 和 服务 器 端 脚 本 的 区 别 。 
. 简 述 ASP.NET 网 页 静态 文本 和 HTML 服务 器 控件 的 区 别 。 

7. 在 一 个 ASP . NET 网 页 中 放置 一 个 标签 服务 器 控件 Labell, 能 否 通过 客户 端 
JavaScript 脚本 访问 它 ” 为 什么 ? 

8. 在 一 个 ASP. NET 网 页 中 放置 一 个 文本 框 服务 器 控件 TextBoxl ,给 出 它 的 ASP.NET 
源 视 图 代码 ,然后 运行 该 网 页 ,给 出 其 客户 端的 HTML 代码 。 

9. 在 一 个 ASP.NET 网 页 中 放置 一 个 命令 按钮 服务 器 控件 Buttonl ,如 果 删 除 runat 一 
"server" 属 性 ,该 网 页 能 否 正确 运行 ? 

10. 简 述 常用 的 ASP.NET 服务 器 控件 类 型 。 


上 机 实验 题 2 


在 ch2 网 站 中 添加 一 个 名 称 为 Experment2 的 单 文件 页 模型 网 页 , 它 含 有 一 个 服务 器 文 
本 框 TextBoxl、 一 个 服务 器 按钮 Buttonl, 一 个 客户 端 文本 框 Textl、 一 个 客户 端 按钮 
Button2 ,两 个 服务 器 标签 Labell 和 Label2 。 

网 页 运行 时 ,用 户 在 TextBoxl 中 输入 字符 串 , 单 击 Buttonl 时 在 Labell 中 显示 该 字符 
串 ,如 图 2.9 所 示 ; 用 户 在 Textl 中 输入 字符 串 , 单 击 Button2 时 在 Label2 中 显示 该 字符 串 ， 
如 图 2. 10 所 示 。 同 时 体会 服务 器 脚本 和 客户 端 脚本 在 执行 上 的 区 别 ( 从 图 2. 10 可 以 看 到 , 客 
户 端 脚本 执行 时 不 影响 原 页 面 的 内 容 ; 反之 ,如 果 在 图 2. 10 所 示 的 运行 界面 上 单 击 Buttonl 、 
Textl 和 Label2 的 内 容 会 被 清空 ) 。 


oO on 上 oo 


倒 htpi/localhost5147 DDO 


@ls https/localhost5147 D = © 大 ocalhost x 
@ localhost 加 输入 : [China 
输入 : [China 加 
| | | | 你 的 输入 : China 
你 的 输入 : China 入 ci 
| 一 [ER 
| Lm v 你 的 输入 : China 


图 2.9 上 机 实验 题 2 网 页 的 运行 界面 一 图 2.10 上 机 实验 题 2 网 页 的 运行 界面 二 


第 3 章 使 用 ASP.NET 进行 HTML5 
和 CSS3 设计 


虽然 可 以 采用 Visual Studio 的 窗 体 设计 器 可 视 化 地 设计 ASP.NET 网 页 ， 
ASP.NET 引擎 运行 这 些 网 页 时 会 将 其 转换 为 纯 HTML, 但 是 掌握 HTML 和 
CSS 对 于 熟练 地 设计 网 页 仍然 是 必要 的 。HTML 提供 了 网 页 的 内 容 和 结构 ， 
CSS 提供 了 网 页 的 格式 化 。 本 章 简要 介绍 在 Visual Studio 中 进行 HTML5 和 
CSS3 设计 的 相关 知识 。 

本 章 学 习 要 点 : 

加 掌握 HTML 的 特点 和 HTML 文档 结构 。 

加 掌握 HTML/XHTML 的 各 种 标记 及 其 作用 。 

回 掌 握 CSS 样式 的 设计 方法 。 

回 掌握 在 ASP.NET 应 用 程序 中 使 用 HTML 和 CSS 的 方法 。 


3.1 HTML 的 基础 知识 


HTML(Hyper Text Markup Language, 超 文本 标记 语言 ) 是 一 种 用 来 表示 
网 页 信息 的 符号 标记 语言 ,是 WWW 的 核心 语言 。HTML5 是 HTML 的 第 5 
次 重大 修改 。 


3.1.1 HTML 概述 

1. HTML.XHTML .HTML5 和 XHTML5 

(1) HTML 

HTML 标记 语言 是 一 套 标记 (或 标签 ),HTML 标记 是 由 尖 括 号 包围 的 关 
键 词 ,如 二 html>,HTML 标记 通常 是 成 对 出 现 的 ,如 二 b 之 和 所 /b 之 。HTML 
元 素 指 的 是 从 开始 标记 到 结束 标记 的 所 有 代码 。HTML 使 用 标记 来 描述 网 
页 ,用 于 告诉 浏览 器 如 何 显示 网 页 。 

因此 ,HTML 是 用 来 描述 网 页 的 一 种 语言 , 它 不 是 一 种 编程 语言 ,而 是 通 
向 WWW 技术 世界 的 “钥匙 ">。HTML 具有 简易 性 和 平台 无 关 性 的 特点 。 

HTML 内 容 丰 富 , 从 功能 上 大 体 可 分 为 文本 结构 设置 .列表 建立 ,文本 属 
性 设置 . 超 链 接 与 图 片 和 多 媒体 插入 ,以 及 对 象 . 表 格 和 表单 的 操作 。 
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(2) XHTML 
由 于 WWW 上 的 许多 网 页 包含 着 糟糕 的 但 仍然 可 以 工作 的 HTML 代码 (即使 它 没有 遵 
守 HTML 规则 ),W3C 于 2000 年 1 月 26 日 推出 了 XHTML1.0 标准 规范 。XHTML 是 更 严 
并 ,更 纯净 的 HTML 版 本 ,并 将 逐渐 取代 HTML。 所 有 新 的 浏览 器 都 支持 XHTML、 
XHTML 与 HTML4.01 兼容 。XHTML 1.0 有 以 下 几 个 版 本 。 
。 XHTML 1.0 Transitional( 过 渡 版 ): 它 是 参照 HTML 4. 01 Transitional 改编 的 , 包 
括 了 Strict 版 本 弃 用 的 呈现 性 元 素 。 其 文件 类 型 描述 为 ， 


<!DOCTYPE html PUBLIC " - //W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www. w3. org/TR/xhtml1/DTD/xhtml1 - transitional. dtd"> 


XHTML 1.0 Strict( 严 格 版 ): 它 是 参照 HTML 4. 01 Strict 改编 的 ,但 不 包括 被 弃 用 
的 元 素 。 其 文件 类 型 描述 为 : 


<! DOCTYPE html PUBLIC " - //W3C//DTD XHTML 1.0 Strict//EN" 
"http://waw. w3. org/TR/xhtml1/DTD/xhtml1 - strict. dtd"> 


XHTML 1.0 Frameset( 框 架 版 ): 它 是 参照 HTML 4. 01 Frameset 改编 的 ,并 允许 于 

网 页 中 定义 框架 元 素 。 其 文件 类 型 描述 为 : 

<!DOCTYPE html PUBLIC " - //W3C//DTD XHTML 1.0 Frameset//EN" 
"http://waw.w3.org/TR/xhtml1/DTD/xhtml1 - frameset. dtd"> 


从 使 用 角度 上 看 ,XHTML 和 HTML 的 区 别 如 下 。 

。 大 小 写 : HTML 不 区 分 大 小 写 ,而 在 XHTML 中 大 小 写 是 敏感 的 ,标记 名 必须 用 小 写 

标记 嵌 套 : 在 HTML 中 ,即便 使 用 了 不 正确 的 嵌 套 ,一 样 可 以 在 很 多 浏览 器 中 使 用 ， 

而 XHTML 要 求 构 套 必须 完全 正确 。 例 如 ,二 b 二 二 i 汪 姓名 二 /i 二 二 /b 二 不 能 写成 

<<b><<i 这 姓名 <</b><</i>。 

。 是 否 有 结束 标记 : 在 HTML 中 .有些 标记 是 可 以 没有 结束 标记 的 ,而 XHTML 要 求 所 
有 标记 都 必须 有 结束 标记 ,例如 ,HTML 中 的 二 br 二 在 XHTML 中 必须 写成 二 br 二 
二 /br 二 或 者 简单 地 写成 二 br / 盖 。 注 意 , 王 br /二 中 的 斜 杠 前 有 一 个 空格 。 

。 引 号 : HTML 中 的 属性 值 可 以 用 引号 引起 来 ,也 可 以 不 使 用 引号 ,但 XHTML 中 要 求 所 
有 属性 值 都 必须 加 引号 ,即使 是 数字 也 需要 加 引号 。 例 如 ,一 img alt 一 "smile"” src 一 
"smile. jpg" / 盖 。 除 此 之 外 .XHTML 还 要 求 属 性 值 不 能 省 略 。 

。id 和 name: 在 XHTML 中 用 id 属性 代替 name 属性 ,每 个 元 素 只 有 一 个 唯一 的 标识 

属性 id。 

样式 的 使 用 : 在 不 使 用 样式 表 的 情况 下 .HTML 中 的 每 一 个 样式 都 可 以 直接 使 用 * 属 

性 名 王 属性 值 ” 的 方法 设置 样式 。 但 在 XHTML 中 ,如 果 不 使 用 样式 表 , 只 能 通过 

style 属性 来 设置 样式 ,如 style 王 "width: 50px; height: 200px"。 

XHTML 是 HTML 与 XML( 扩 展 标记 语言 ) 的 结合 物 ,实际 上 以 XML 重 构 的 HTML 
4.01 就 是 XHTML 1.0, 所 以 XHTML 可 以 被 所 有 支持 XML 的 设备 读 取 。 采 用 XHTML 可 
以 编写 出 拥有 和 良好 结构 的 HTML 文档 。 

但 XHTML 只 是 在 内 容 结构 上 改进 原 有 的 HTML ,后 来 推出 的 XHTML 2.0 也 仅仅 在 
XHTML 1.0 的 基础 上 更 加 注重 网 页 规范 和 可 用 性 ,而 缺乏 交互 性 。 
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(3) HTML5 

正 是 由 于 XHTML 的 缺陷 ,W3C 于 2014 年 10 月 29 日 又 推出 了 HTML5 标准 规范 。 实 
际 上 ,在 此 之 前 的 几 年 时 间 里 已 经 有 很 多 开发 者 陆续 使 用 了 HTML5 的 部 分 技术 ,如 Firefox、 
Google Chrome、Opera、Safari 4 十 IE 9 或 更 高 版 本 等 都 已 支持 HTML5。 

HTML5 将 会 取代 1999 年 制定 的 HTML4. 01、.XHTML1. 0 标准 ,以 期 能 在 互联 网 应 用 
迅速 发 展 的 时 候 使 网 络 标准 符合 当代 的 网 络 需 求 , 为 桌面 和 移动 平台 带 来 无 颖 衔接 的 丰富 
内 容 。 

HTML5 作为 下 一 代 的 HTML, 通 过 提供 跨 浏览 器 标准 改变 了 Web 应 用 程序 的 开发 方 
式 , 提 高 网 页 性 能 ,增加 页 面 交 互 。 同 时 HTML5 吸取 了 XHTML2.0 的 一 些 建议 ,包括 一 些 
用 来 改善 文档 结构 的 功能 。 其 主要 改进 包括 取消 了 一 些 过 时 的 HTML4 标记 ,将 内 容 和 展示 
分 离 ,增加 了 一 些 全 新 的 表单 输入 对 象 和 提供 了 一 些 全 新 的 .更 合理 的 标记 等 ,如 新 增 了 
section varticle video ,footer 等 标记 。 

(4) XHTML5 

以 XML 重 构 的 HTML5 就 是 XHTML5, 即 HTML5 十 XML=XHTML5。 

本 章 的 示例 采用 Visual Studio 2012 设计 网 页 ,并 遵守 XHTML5 标准 规范 。 为 此 ,在 
Visual Studio 2012 中 选择 “工具 | 选项 "命令 ,然后 选择 “文本 编辑 器 |HTML | 验证 ” 结 点 ,再 选 
择 XHTML5 或 HTML5 模式 作为 验证 的 目标 ,如 图 3. 1 所 示 。 除 非特 别 指定 ,本 书后 面 的 
HTML 指 的 都 是 XHTML5。 


图 3.1 设置 XHTML5 模式 作为 验证 的 目标 


说 明 : 在 采用 Visual Studio 设计 网 页 时 ,通过 设计 视图 界面 所 设计 的 ASP.NET 控件 会 
遵守 XHTML5 规则 ,但 是 要 确保 最 终 的 网 页 是 与 XHTML5 兼容 的 ,必须 保证 开发 人 员 加 入 
的 任何 静态 内 容 也 遵守 这 些 规则 。 选 择 XHTML5 或 HTML5 模式 作为 验证 的 目标 就 是 为 了 
达到 这 个 目的 。 
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2. HTML 文档 结构 

HTML 文档 就 是 网 页 , 它 是 一 种 普通 文本 文件 ,网 页 可 以 是 网 站 的 一 部 分 ,也 可 以 独立 存 
在 ,可 以 用 记事 本 等 文本 编辑 器 进行 编辑 ,本 书 使 用 Visual Studio 编辑 HTML 文档 。 纯 
HTML 文件 的 扩展 名 为 . html 等 。 

从 结构 上 看 ,HTML 文档 一 般 分 为 三 部 分 , 即 DOCTYPE .文档 头 部 (head) 和 文档 主体 
(body) ,其 基本 结构 如 图 3. 2 所 示 。 


<!DOCTYPE html> 一 表示 是 HTML 文 档 
<html xmlns="http://www.w3.org/1999/xhtml"> 


<head> 


访 一 一 HTML 文档 的 头 部 
HTML 文档- 一 | </head> 
<body> 


一 一 一 HTML 文 档 的 主体 


</body> 
</html> 


图 3.2 HTML 文档 的 基本 结构 


其 中 ,DOCTYPE 是 文档 类 型 的 声明 。DOCTYPE 标记 是 一 种 标准 通用 标记 语言 的 文档 
类 型 声明 , 它 的 目的 是 要 告诉 标准 通用 标记 语言 解析 器 应 该 使 用 什么 样 的 文档 类 型 定义 来 解 
析 文 档 。 其 他 所 有 HTML 代码 都 包含 在 二 html 这 > 和 二/html 二 标记 之 间 。 

在 XHTML 中 ,二 html 二 的 xmlns 属性 是 必需 的 , 它 定义 XML 的 命名 空间 。 不 过 ,即使 
XHTML 文档 中 的 二 html 二 没有 使 用 此 属性 , W3C 的 验证 器 也 不 会 报错 。 这 是 因为 xmlns= 
http://www. w3. org/1999/xhtml 是 一 个 固定 值 (W3C 的 默认 命名 空间 ) ,即使 没有 包含 它 ， 
此 值 也 会 被 添加 到 二 html 二 标记 中 。 


3.1.2 HTML 头 部 和 主体 标记 

1. HTML 的 头 部 

HTML 头 部 一 般 用 于 标记 文档 的 某 些 信息 , 放 于 二 head 二 与 一 /head> 之 间 。 它 们 通常 
不 会 显示 在 网 页 上 。 

用 于 HTML 头 部 的 标记 有 < 到 title 之 和 二 meta 二 等 ,其 中 一 title 之 是 任何 网 页 必须 有 的 ， 
其 他 均 为 可 选项 。 

(1) title 标记 

基本 用 法 : 


<title> … </title> 


该 标记 用 于 指定 文档 的 标题 ,通常 ,一 title> … < 到 /title 之 中 间 的 文字 会 显示 在 浏览 器 的 
标题 栏 上 。 一 般 用 简明 扼要 的 文字 概括 文档 的 主要 内 容 或 主题 ,不 超过 64 个 ASCII 码 字 符 
长 度 ,因为 如 果 过 长 ,窗口 的 标题 栏 无 法 容纳 。 

(2) meta 标记 

基本 用 法 : 

<meta 属性 = "属性 值 "/> 
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该 标记 用 于 描述 网 页 的 具体 摘要 信息 ,包括 文档 的 内 容 类 型 .字符 编码 信息 .搜索 关键 字 、 
网 站 提供 的 功能 和 服务 的 详细 描述 等 。 其 内 容 并 不 在 浏览 器 中 显示 。 其 中 ,http-equiv 属性 
把 content 属性 关联 到 HTTP 头 部 ; name 属性 把 content 属性 关联 到 一 个 名 称 ; content 属 
性 定义 与 http-equiv 或 name 属性 相关 的 元 信息 ( 必 选 ); charset 属性 定义 文档 的 字符 编码 。 

例如 ,以 下 语句 指定 若干 关键 字 : 

<meta name = "keywords" content = "Visual Studio, ASP.NET, 动态 网 页 设计 "> 

例如 ,以 下 语句 向 浏览 器 报告 本 文档 作者 是 李兵 : 

<meta name = "作者 ”content = "李兵 "> 

例如 ,以 下 语句 表示 文档 的 内 容 类 型 为 html 类 型 ,字符 编码 为 国际 通用 的 字符 编码 : 

<meta http - equiv = "Content ~ Type" content = "text/html; charset = utf - 8"/> 


2. 主体 标记 

基本 用 法 : 

<body> … </body> 

去 body> 标 记 定 义 文档 的 主体 。body 标记 包含 文档 的 所 有 内 容 ( 例 如 文本 、 超 链接 、 图 
像 . 表 格 和 列表 等 )。 

为 了 在 浏览 器 中 显示 完整 内 容 , 需 在 网 页 中 添加 文本 、 图 形 、 表 格 、 表 单 、 超 链接 等 网 页 元 
素 。HTML 语言 通过 各 种 标记 控制 这 些 网 页 元 素 的 显示 方式 。 一 个 含有 header、section 和 
footer 元 素 的 网 页 的 文档 主体 部 分 的 基本 结构 如 下 : 

<body> 


<header> 

<! -一定 义 页 面 的 页 眉 -一 > 
</header > 
<section> 

<== 半 训 入 == 
</section> 
<footer> 

<! 一 一定 义 页 面 的 页 脚 --> 
<footer> 

</body > 

注意 : 在 HTML5 中 ,所 有 body 元 素 的 “呈现 属性 " 均 不 被 赞成 使 用 ,可 以 使 用 CSS 样式 
或 style 属性 取代 它 。 

【 例 3.1】 在 D 盘 ASP.NET 目录 中 建立 一 个 ch3 的 子 目录 ,将 其 作为 网 站 目录 ,创建 一 
个 WebForml. html 网 页 ,其 功能 是 说 明 HTML 头 部 和 主体 标记 的 应 用 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012 。 

@ 选择 “文件 | 新 建 | 网 站 ”命令 ,出 现 “ 新 建 网 站 ”对 话 框 ,选择 “ASP.NET 空 网 站 ”模板 ， 
选择 “Web 位 置 ?为 "文件 系统 ”, 单 击 “ 浏 览 "按钮 ,选择 *D:\ASP.NETNch3? 目 录 , 单 击 “ 确 定 ” 
按钮 ,创建 一 个 空 的 网 站 ch3。 

@ 选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch3” 对 话 框 ,在 中 间 列 表 中 选择 “HTML 
页 ”, 将 文件 名 称 改 为 WebForml. html, 单 击 “ 添 加 ”按钮 。 

说 明 : 这 种 “HTML 页 ”模板 类 型 的 网 页 只 能 采用 单 文 件 页 模型 设计 。 
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@ 进入 源 视 图 ,设计 其 HTML 代码 如 下 (只 有 粗 体 部 分 的 代码 是 新 添加 的 ,其 余部 分 是 
Visual Studio 自动 产生 的 ) : 


<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head > 
<meta http - equiv= "Content - Type" content = "text/htm1; charset = utf — 8"/> 
<title > 第 3 章 例 3.1</title> 


</head> 
<body> 
中 华人 民 共 和 国 <title> 部 分 
</body> <body> 部 分 
</html > 
该 网 页 在 IE 浏览 器 中 的 显示 结果 如 图 3. 3 所 示 。 图 3.3 WebForml.html 网 页 的 
说 明 : 尽管 设置 Visual Studio 2012 支持 的 是 显示 结果 


XHTML5 ,对 于 一 body 之 不 赞成 使 用 "呈现 属性 ”, 但 
有 时 出 现 违反 情况 时 仍然 可 以 运行 网 页 。 例如 ,将 例 3.1 代码 中 的 二 body 二 行 改 为 以 下 语句 
时 网 页 仍 可 正常 运行 ,但 会 在 错误 列表 窗口 中 给 出 如 图 3.4 所 示 的 警告 消息 。 


<body background = "../Images/imgl. bmp" text =" 间 FF0000"> 


Y-|@oNMie ||A2E || 00 人 We 搜索 错误 列表 只- 
| 说明 和 文件 行 列 项 目 

A 

| 向 2 验证 XHTML5): 特性 “text” 不 是 元 素 “body” 的 有 效 符 性. WebFormlhtm| 9 41 ch2 


图 3.4 给 出 警告 消息 的 错误 列表 窗口 
下 面 按 功能 介绍 过 body 之 标记 中 常见 的 HTML 标记 。 


3.1.3 基础 标记 

1. 标题 标记 

基本 用 法 : 

<hn> … </mn>n=1, 2, 3, 4, 5, 6 

该 标记 确定 字体 的 显示 方式 , 按 标题 级 别 突出 显示 这 些 标题 文字 ,字体 从 hl1~h6 逐 级 减 
小 。 用 户 可 以 使 用 style 属性 规定 元 素 的 行内 样式 ,样式 定义 是 一 个 或 多 个 由 分 号 分 隔 的 CSS 
属性 和 值 。 

例如 ,以 下 代码 以 hl 标题 文字 、 蓝 色 和 居中 格式 显示 “中 华人 民 共 和 国 ”， 

<hl style= "color:blue; text -align:center"> 中 华人 民 共 和 国 </hl > 

2. 段落 标记 

基本 用 法 : 

<p> … </p> 

该 标记 用 于 定义 一 个 段落 ,可 以 忽略 文档 中 原 有 的 回 车 和 换行 来 定义 一 个 新 段落 ,换行 并 
插入 一 个 空 行 。 
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3. 换行 标记 
基本 用 法 : 


<br /> 


该 标记 强行 中 断 当 前 行 ,使 后 续 文 本 在 下 一 行 显示 。 
4. 水 平 线 标记 
基本 用 法 : 


<hr /> 


该 标记 在 文档 中 添加 一 条 水 平 线 , 用 来 分 隔 文档 。 
5. 定义 注释 标记 
基本 用 法 : 


et 


注释 标签 用 于 在 源 代码 中 插入 注释 ,注释 不 会 显示 在 浏览 器 中 。 

【 例 3.2】 在 ch3 网 站 中 添加 一 个 WebForm2. html 网 页 ,其 功能 是 说 明 HTML 基础 标 
记 的 应 用 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch3 网 站 ,选择 * 网 站 | 添加 新 项 命令, 出现 * 添 加 新 项 -ch3” 对 话 框 , 在 中 间 列 表 中 
选择 “HTML 页 ”, 将 文件 名 称 改 为 WebForm2. html, 单 击 * 添 加 ”按钮 。 

@ 进入 源 视图 ,设计 其 HTML 代码 如 下 : 

<!DOCTYPE html > 


<htm]l xmlns = "http://www.w3.org/1999/xhtml"> 
<head> 
<meta http - equiv= "Content ~ Type”" content = "text/htm1; charset = utf- 8"/> 
<title > 第 3 章 例 3.2 </title> 
</head> 
<! -- 文档 的 主体 --> 


< body> (SOs hapVnlocalhost5380 D -= | 从 
<h3> 中 华人 民 共和 国 </h3> ELSE * hs 


<hr /> 

<p> 中 华人 民 共 和 国 </p> 中 华人 民 共 和 国 

<br /> 

<h5> 中 华人 民 共和 国 </h5> | 学 ARS 国 
</body> 


</html > 图 3.5 WebForm2.html 网 页 的 
该 网 页 在 IE 浏览 器 中 的 显示 结果 如 图 3. 5 所 示 。 显示 结果 


3.1.4 格式 标记 
几 个 常见 的 格式 标记 如 表 3. 1 所 示 。 
表 3.1 几 个 常见 的 格式 标记 及 其 说 明 


格式 标记 功 能 说 明 
二 人 呈现 类 似 打 字 机 或 者 等 宽 的 文本 效果 
<i> 显示 斜体 文本 效果 


<b> 呈现 粗 体 文本 效果 
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续 表 
格式 标记 功 能 说 明 
<em> 定义 强调 文本 
=small> 呈现 小 号 字体 效果 
strong> 定义 语气 更 为 强烈 的 强调 文本 
=sub> 定义 下 标 文本 
<sup> 定义 上 标 文本 
二 mark 二 定义 有 记号 的 文本 HTML5 新 增 标 记 
meter> 定义 预定 义 范围 内 的 度量 HTML5 新 增 标记 
time> 定义 日 期 /时 间 HTML5 新 增 标记 


【 例 3.3】 在 ch3 网 站 中 添加 一 个 WebForm3. html 网 页 ,其 功能 是 说 明 常见 的 格式 标记 
的 应 用 。 

解 : 其 步骤 如 下 。 

GD 打开 ch3 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch3” 对 话 框 ,在 中 间 列 表 中 
选择 “HTML 页 ”, 将 文件 名 称 改 为 WebForm3. html, 单 击 “ 添 加 ”按钮 。 

@ 进入 源 视图 ,设计 其 HTML 代码 如 下 : 


<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head> 
<meta http - equiv= "Content ~ Type" content = "text/html; charset = utf -8"/> 
<title > 第 3 章 例 3.3</title> 
</head> 
<body> 
This text is <b> bold</b> 
<br /> 
This text is < strong > strong </ strong > 
<br /> 
<em>This text is <mark> emphasized </mark ></em> 


<br /> i 
This text is <i> italic </i> [Breecahorss0 # 
<br /> 剧 第 3 章 人 3.3 x 


This text is < small > small </small > This text is bold 


<br /> This text is strong 

This text is eiphiasized 

This text contains < sub > subscript </sub> This text is italic 

<br /> 用 This text is smatl 

This text contains < sup > superscript </sup> Tis set 

tt Pp 0 This text contains Prt 
<time></time> 
</body> 
</html > 图 3.6 WebForm3.html 网 页 的 

显示 结果 


该 网 页 在 IE 浏览 器 中 的 显示 结果 如 图 3.6 所 示 。 


3.1.5 表格 标记 


表格 是 人 们 处 理 数 据 最 常用 的 一 种 形式 ,一 个 表格 由 表 标 题 ` 行 , 列 标题 和 单元 格 组 成 。 
表格 不 仅 可 以 用 来 罗列 数据 ,还 可 以 将 文本 、 图 像 、 超 链接 等 各 种 对 象 放 到 表格 中 进行 定位 ,从 
而 制作 出 排版 精美 的 网 页 。 几 个 常见 的 表格 标记 如 表 3. 2 所 示 。 
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表 3.2 几 个 常见 的 表格 标记 及 其 说 明 


表格 标记 功 能 
<table> 定义 表格 
caption> 定义 表格 标题 
<th> 定义 表格 中 的 表 头 单元 格 
<<tr> 定义 表格 中 的 行 
<td> 定义 表格 中 的 单元 
=thead> 定义 表格 中 的 表 头 内 容 
=tbody> 定义 表格 中 的 主体 内 容 
=tfoot> 定义 表格 中 的 表 注 内 容 ( 脚 注 ) 
<col> 定义 表格 中 一 个 或 多 个 列 的 属性 值 
<colgroup> 定义 表格 中 供 格式 化 的 列 组 


在 设计 表格 时 常用 下 面 的 属性 : 对 于 一 table 之 标记 ,border 表示 是 否 有 边框 ,为 "0" 表 示 
没有 边框 ,为 "1" 表 示 有 边框 ; cellpadding 规定 单元 边沿 与 其 内 容 之 间 的 空白 ; cellspacing 规 
定单 元 格 之 间 的 空白 。 

对 于 单元 格 ,colspan 一 "2" 表 示 横 跨 两 列 的 单元 格 ,rowspan 王 "2" 表 示 横 跨 两 行 的 单元 
格 ; background 设置 单元 格 背景 图 像 ， bgcolor 设置 单元 格 背景 颜色 。 

另外 ,在 一 个 表格 中 可 以 册 套 另 一 个 表格 。 

【 例 3.4】 在 ch3 网 站 中 添加 一 个 WebForm4. html 网 页 ,其 功能 是 说 明 表格 标记 的 
应 用 。 

解 : 其 步骤 如 下 。 

@ 打开 ch3 网 站 ,选择 “网 站 | 添加 新 项 "命令 ,出 现 “ 添 加 新 项 -ch3” 对 话 框 ,在 中 间 列 表 中 
选择 “HTML 页 ”, 将 文件 名 称 改 为 WebForm4. html, 单 击 “ 添 加 ”按钮 。 

@ 进入 源 视图 ,设计 其 HTML 代码 如 下 : 


<!DOCTYPE html > 
<html xmlns = "http://www. w3.org/1999/xhtml"> 
<head > 
<meta http - equiv= "Content- Type" content = "text/html; charset = utf -8"/> 
<title > 第 3 章 例 3.4</title> 
</head> 
<body> 
< table border = "1" style= "text - align:center;width:300px; border:double"> 
<caption><b> 学 生 情况 表 </b></caption> 
<tr> 
<th> 学 号 </th> 
<th> 姓 名 </th> 
<th> 性 别 </th> 
<th> 班 号 </th> 
</tr> 
<tr> 
<td>101</td> 
<td> 王 华 </td> 
<td> 女 </td> 
<td rowspan = "3"> 0701 </td> 
</tr> 
< 
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<td>103 </td> 


<td> 李 民 </td> 
<td> 男 </td> 
</tr > 
<tr> 
<td>108 </td> 
<td> 张 丽 </td> 
<td> 女 </td> 
</tr> - 
<tr> = 
<td>112 </td> rr 
<td> 陈 强 </td> m4 x 
<td> 男 </td> 学 生 情 况 表 
<td rowspan = "2"> 0702 </td> 学 号 | 妊 名 | 性 别 | 班 号 ] 
</tr > 101 王 华 女 
ES 103 | 季 民 勇 0701 
<td>138 </td><td> 李 兵 </td> 108 | 张 丽 女 
<td> 男 </td> 112 陈强 男 0702 | 
</tr> 138 李兵 男 
</table> 
</body> 图 3.7 WebForm4.html 网 页 的 显示 结果 
</html > 


该 网 页 在 下 浏览 器 中 的 显示 结果 如 图 3. 7 所 示 。 首 先 采用 二 table 二 标记 创建 一 个 表格 ， 
其 标题 为 "学 生 情 况 表 ”, 然 后 插入 6 行 ,每 行 4 列 ,第 2、3、4 行 的 第 4 列 是 合并 的 (通过 
rowspan 一 "3" 来 实现 ) ,第 5.6 行 的 第 4 列 也 是 合并 的 。 
3.1.6 样式 / 节 标 记 
主要 的 样式 / 节 标 记 如 表 3. 3 所 示 。 
表 3.3 主要 的 样式 / 节 标 记 及 其 说 明 


样式 / 节 标 记 功 能 说 明 

=style> 定义 文档 的 样式 信息 

=<div> 定义 文档 中 的 块 

=span> 定义 文档 中 的 节 

header> 定义 section 或 page 的 页 眉 HTML5 新 增 标记 

一 footer> 定义 section 或 page 的 页 脚 HTML5 新 增 标记 

=section> 定义 section HTML5 新 增 标记 

=article> 定义 文章 HTML5 新 增 标记 

aside> 定义 页 面 内 容 之 外 的 内 容 HTML5 新 增 标记 

=details> 定义 元 素 的 细节 HTML5 新 增 标记 

=dialog> 定义 对 话 框 或 窗口 HTML5 新 增 标 记 

=summary> 为 二 details 二 元 素 定义 可 见 的 标题 HTML5 新 增 标 记 
1. style 


二 style 二 标记 用 于 为 HTML 文档 定义 样式 信息 。 在 style 中 可 以 规定 在 浏览 器 中 如 何 
呈现 HTML 文档 。 其 详细 的 使 用 方法 见 3. 2 节 介绍 。 

说 明 : 对 于 style 而 言 , 既 可 以 用 作 HTML 标记 ,也 可 以 用 作 HTML 属性 ,用 户 要 注意 两 
者 的 区 别 。 
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2. 二 div 二 标记 
基本 用 法 : 
<div 属性 = "属性 值 "> … </div> 


该 标记 可 定义 文档 中 的 块 ,可 以 把 文档 分 割 为 独立 的 \ 不 同 的 部 分 。 它 是 内 容 自 动 地 开始 


一 个 新 行 。 
3. 二 section 二 标记 
基本 用 法 : 
< section 属性 = "属性 值 "> … </section> 


该 标记 可 定义 文档 中 的 节 (section), 如 章节 、 页 眉 、 页 脚 或 文档 中 的 其 他 部 分 。 


说 明 : 一 divy 之 、 忆 section 之 和 < 一 article> 等 节 标 记 通 常用 于 将 若干 HTML 元 素 组 合 在 一 


起 ,可 以 采用 绝对 和 相对 定位 方式 进行 页 面 布局 ,详细 内 容 见 3.2.2 节 的 CSS 属性 。 


应 用 。 
解 : 其 步骤 如 下 。 


【 例 3.5】 在 ch3 网 站 中 添加 一 个 WebForm5. html 网 页 ,其 功能 是 说 明 样 式 / 节 标记 的 


@ 打开 ch3 网 站 ,选择 “网 站 | 添加 新 项 "命令, 出现 “添加 新 项 -ch3” 对 话 框 ,在 中 间 列 表 中 


选择 "HTML 页 ”, 将 文件 名 称 改 为 WebForm5. html, 单 击 “ 添 加 ”按钮 。 
@ 进入 源 视图 ,设计 其 HTML 代码 如 下 : 
<!DOCTYPE html > 
<html xmlns = "http://www. w3.org/1999/xhtml"> 
<head> 


<meta http - equiv= "Content ~ Type" content = "text/html; charset = utf -8"/> 
<title > 第 3 章 例 3.5</title> 
</head> 
<body> 
<div style = "color:blue"> 
<h3 > 要 闻 </h3 > 
<p>" 一 带 一 路 "十 年 目标 : 年 贸易 额 2.5 万 亿美 元 </p> 
</div> 
<section> 
<hl > 体育 新 闻 </hl > 
<“p> 发 展 足球 绝 不 是 说 不 开展 别 的 体育 活动 </p> 


</section > 
</body > 
</html > 


该 网 页 在 IE 浏览 器 中 的 显示 结果 如 图 3.8 所 二 
示 , 分 别 采 用 一 div 盖 和 二 section 二 标记 将 显示 的 所 ||@@s3sm35 x | 


有 文字 分 为 两 组 。 要 阿 


3.1.7 列表 标记 一 带路 "十 年 目标 ， 年 贸易 额 25 万 亿美 元 


列表 用 于 显示 一 组 意义 相似 的 列表 项 .每 个 列 | 体育 新 闻 


表 项 由 一 个 文字 串 构成 。 列 表 分 为 有 序列 表 、 无 序 | 发 展 足球 绝 不 是 说 不 开展 别 的 体育 活动 
列表 和 自 定义 列表 。 - - 


图 3.8 WebForm5.html 网 页 的 显示 结果 
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1. 有 序列 表 
基本 用 法 : 


<ol start = "起 始 序号 " type= "符号 类 型 "> 
<1i>…</1i> 
<1i>…</1i> 


</ol> 
其 功能 是 建立 有 序列 表 。start 属性 指出 数字 序列 的 起 始 值 ; type 属性 指出 数字 序号 的 
样式 , 即 符号 类 型 , 取 值 如 下 。 

。 1: 表示 阿拉 伯 数 字 1、2、3 等 ,此 为 默认 值 。 

。 a: 表示 小 写字 母 a、b.c 等 。 

。 A: 表示 大 写字 母 A、B、C 等 。 

。i; 表示 小 写 罗 马 数字 i\ii\iii\iv 等 。 

。 I: 表示 大 写 罗 马 数字 IIILIIIIV 等 。 

< 一 li 盖 标记 用 于 定义 列表 项 ,位 于 一 ol> 和 一 /ol 之 之 间 , 它 有 两 个 常用 的 属性 。 
。 type: 指出 该 列表 项 的 符号 类 型 (其 取 值 与 ol 标记 的 type 属性 取 值 相同 ) 。 
。 value: 新 的 数字 序列 起 始 值 ,以 获取 非 连续 的 数字 序列 。 

2. 无 序列 表 

基本 用 法 : 

<ul type = "项 目 符号 "> 

<1i>…</1i> 
<1i>…</1i> 
</ul> 
其 功能 是 建立 无 序列 表 。 每 个 列表 项 以 无 编号 的 形式 列 出 来 ,其 前 有 一 个 项 目 符号 ,由 属 
性 type 决定 ,type 的 取 值 如 下 。 

。 disc: 使 用 实心 圆 作 为 项 目 符号 ,此 为 默认 值 。 

。 circle: 使 用 空心 圆 作 为 项 目 符号 。 

。 square: 使 用 方块 作为 项 目 符号 。 

3. 自 定义 列表 

基本 用 法 : 


<dl> 
<dt>…</dt> 
<dd>…</dd> 
<dd>…</dd> 


</dl > 
自 定义 列表 属于 描述 性 列表 ,用 于 表示 信息 的 层次 关系 。 


注意 : 根据 文档 的 具体 要 求 , 自 定义 列表 可 以 谋 套 使 用 。 
【 例 3.6】 在 ch3 网 站 中 添加 一 个 WebForm6. html 网 页 ,其 功能 是 说 明 列 表 标 记 的 


峡 


用 。 
解 : 其 步骤 如 下 。 
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@ 打开 ch3 网 站 ,选择 “网 站 | 添加 新 项 "命令, 出现 “添加 新 项 -ch3” 对 话 框 ,在 中 间 列 表 中 
选择 “HTML 页 ”, 将 文件 名 称 改 为 WebForm6. html, 单 击 “ 添 加 ”按钮 。 
@ 进入 源 视图 ,设计 其 HTML 代码 如 下 : 


<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head> 
<meta http - equiv= "Content — Type" content = "text/html; charset = utf— 8"/> 
<title > 第 3 章 例 3.6</title> 
</head> 
<body> 
<! -- 插入 一 个 1 行 3 列 的 表格 --> 
< table border = "1" style= "text ~ align:center;width:400px; border:double"> 
<tr> 
<td> 
<h3 > 球 类 </h3> 
<ol start = "1" type = "a"> 
<1i> 足 球 </1i> 
<1i> 篮 球 </1i> 
<1i > 排球 </1i> 
<1i> 乒 乓 球 </1i> 
</ol> 
</td> 
<td> 
< h3 > 球 类 </h3 > 
<ul> 
<1i> 足 球 </1i> 
< 1i> 篮 球 </1i> 
<1i> 排 球 </1i> 
<1i> 乒 乓 球 </1i> 
</u> 
</td> 
<td> 
<h3> 体 育 </h3> 
<dl> 
<dt> 球 类 </dt> 
<dd> 足 球 </dd> 
<dd> 篮 球 </dd> 
<dd> 排 球 </dd> 
<dd> 乒 乓 球 </dd> 
<dt> 田 径 </dt> 
<dd> 跑 步 </dd> 
<dd> 铅 球 </dd> 
<dd> 跳 高 </dd> 
<dd> 跳 远 </dd> 
</dl> 
</td> 
</tr> 
</table> 
</body > 
</html > 


该 网 页 在 IE 浏览 器 中 的 显示 结果 如 图 3.9 所 示 。 该 例 采 用 二 table 二 标记 建立 一 个 1 行 
3 列 的 表格 ,第 1 列 插入 一 个 有 序列 表 , 第 2 列 插入 一 个 无 序列 表 , 第 3 列 插入 一 个 自 定义 
列表 。 
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后 笃 httpy/localhost63801/WebFom pv-c 耳 汪 E3 
情 备 3 宇 3.5 x EE 


体育 
球 
球 类 球 类 寺 | 
篮球 
a ”足球 。 ”足球 排球 
b 息 球 | . 短 球 乒乓 球 
。 排球 | 。 排球 田径 
dL 乒乓 球 ， 乒乓 球 跑步 
铝 球 
跌 训 
跳远 


图 3.9 WebForm6. html 网 页 的 显示 结 


3.1.8 超 链接 标记 


超 链接 (或 链接 ) 用 于 实现 浏览 转向 功能 ,是 Web 网 页 的 基本 功能 之 一 ,通过 它 将 众多 网 
页 组 织 到 一 起 ,主要 的 超 链 接 标 记 如 表 3.4 所 示 。 
表 3.4 主要 的 超 链接 标记 及 其 说 明 
链接 标记 功 能 说 明 
<a> 定义 锚 
< 一 link> ”定义 文档 与 外 部 资源 的 关系 ,最 常见 的 用 途 是 链接 样式 表 , 如 
<link rel= "stylesheet" type= "text/css" href="theme. css" /> 


二 nav ”定义 导航 超 链接 。 如 果 文 档 中 有 前 后 按钮 , 则 应 该 把 它 放 到 二 nav 二 标 ” HTML5 新 增 标记 
记 中 


超 链 接 标 记 最 常用 的 属性 是 href, 它 指出 转向 的 URL。 另 外 ,target 属性 指出 该 超 链接 
指向 的 HTML 文档 在 指定 目标 窗口 中 打开 ,target 属性 取 值 及 其 说 明 如 表 3. 5 所 示 。 


表 3.5 目标 窗口 名 称 及 其 说 明 


名 称 说 明 
_blank 将 超 链 接 的 内 容 显示 在 新 的 浏览 器 窗口 中 
_parent 将 超 链接 的 内 容 显示 在 父 窗口 中 
_search 将 超 链接 的 内 容 显 示 在 搜索 窗口 中 
_self 将 超 链接 的 内 容 显 示 在 当前 窗口 中 
top 将 超 链接 的 内 容 显示 在 浏览 器 主 窗 口中 
去 a> 标 记 有 以 下 两 种 基本 用 法 。 
1. 设置 锚 点 (书签 ) 
格式 为 : 


<a name= " 锚 点 名 称 " > … </a> 


这 相当 于 书签 , 即 在 网 页 中 的 某 一 处 设置 一 个 标记 ,其 他 的 超 链接 可 以 指向 它 。 


58 
P.NET 4.5 动态 网 站 设计 教程 一 一 基于 C# 5. 0 十 SQL Server 2012 


2. 设置 超 链接 
HTML 的 很 多 诱 人 之 处 就 来 源 于 这 个 标记 。 有 了 它 , 访 问 者 可 以 在 一 个 文档 的 不 同 部 分 
跳 转 ,也 可 以 跳 到 其 他 文档 。 其 格式 为 : 


<a href = "url"> … </a> 


其 中 ,URL 可 以 使 用 绝对 路 径 或 相对 路 径 。 

【 例 3.7】 在 ch3 网 站 中 添加 一 个 WebForm7. html 网 页 ,其 功能 是 说 明 超 链接 标记 的 应 用 。 

解 : 其 步骤 如 下 。 

@ 打开 ch3 网 站 ,选择 * 网 站 | 添加 新 项 命令, 出现“ 添加 新 项 -ch3? 对 话 框 , 在 中 间 列 表 中 
选择 “HTML 页 ”, 将 文件 名 称 改 为 WebForm7. html, 单 击 “ 添 加 ”按钮 。 

@ 进入 源 视 图 ,设计 其 HTML 代码 如 下 : 


<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtm]l"> 
<head > 
<meta http - equiv= "Content ~ Type" content = "text/htm1; charset = utf— 8"/> 
<title > 第 3 章 例 3.7</title> 
</head> 
<body> 
<! -- 插入 一 个 2 行 1 列 的 表格 --> 
< table border = "1" style = "text ~ align:center;width:400px; border:double"> 
<tr> 
<td> 
<h3 > 锚 点 标记 示例 </h3 > 
<p><a href = "WebForml. html"> WebForml </a> 指 向 本 网 站 一 个 页 面 的 链接 </p> 
<p><a href = "http://www.whu. edu. cn/"> 武 汉 大 学 </a> 指 向 WWW 网 站 的 链接 </p> 
</td> 
</tr> 
E> 
<td> 
<h3 >nav 标记 示例 </h3 > 
<nav> 
<a href = "WebForm3. html"> 首 网 页 </a> 
<a href = "WebForm2. html"> 前 一 个 网 页 </a> 
<a href = "WebForm4. html"> 后 一 个 网 页 </a> 


</nav > 
<br /> 
</td> 
2 (=.5 ES 
</table> "* 
</body > 总 备 3 章 3.7 *| | Ee“ 
</html > 
错 点 标记 示例 
该 网 页 在 IE 浏览 器 中 的 显示 结果 如 | WebFomm1 指 向 本 网 站 一 个 页 面 的 链接 | 
图 3. 10 所 示 。 单 击 其 中 的 各 个 超 链接 便 转向 相 武汉 大 学 指向 WWW 网 站 的 链接 
应 的 网 页 。 
加 nav 标 记 示例 
3.1.9 ”图像 标记 首 加 页 前 一 个 网 页 后 一 个 网 页 


图 像 是 最 早 引 进 Web 页 的 多 媒体 对 象 .由 = 
于 有 了 图 像 .Web 可 以 图 文 并 茂 地 向 用 户 提供 图 3.10 WebForm7.html 网 页 的 显示 结果 
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信息 ,成 倍 地 加 大 了 它 所 提供 的 信息 量 , 而 且 图 像 的 引入 也 极 大 地 美化 了 Web 网 页 。Web 网 
页 制作 的 很 多 技巧 就 是 如 何 利用 好 图 像 ,使 网 页 美观 匀称 。 用 户 可 以 使 用 图 像 标 记 链 入 图 像 ， 
主要 的 图 像 标 记 如 表 3. 6 所 示 。 
表 3.6 主要 的 图 像 标记 及 其 说 明 


图 像 标记 功 能 说 明 
<img> 定义 图 像 
<map> 定义 图 像 映射 
~<area> 定义 图 像 地 图 内 部 的 区 域 
<canvas> 定义 图 形 HTML5 新 增 标记 
<figcaption> 定义 figure 元 素 的 标题 HTML5 新 增 标记 
<figure> 定义 媒介 内 容 的 分 组 以 及 它们 的 标题 HTML5 新 增 标记 
1. 二 img 二 标记 


二 img 二 标记 的 基本 用 法 : 

<img 属性 =" 属 性 值 "> 

图 像 标 记 的 必需 属性 如 下 。 

。 src: 链接 图 像 的 URL 位 置 ,通常 采用 相对 路 径 ,例如 “../Images/logo. gif” 就 是 一 个 

相对 路 径 , 表 示 当 前 目录 的 上 一 级 目录 中 Images 目录 中 的 logo. gif 文件。 图像 可 以 
是 jpeg、gif 或 png 文件 。 

。 alt: 该 图 形 的 信息 ,如 文件 名 文件 大 小 和 描述 等 。 

注意 ; 一 img 之 标记 并 不 会 在 网 页 中 插入 图 像 , 而 是 从 网 页 上 链接 图 像 。 一 img 二 标记 创 
建 的 是 被 引用 图 像 的 占 位 空间 。 

2. 绝对 URL 和 相对 URL 

绝对 URL 是 包含 网 站 域名 和 协议 信息 (http:// 前 级 ) 的 完整 路 径 ,例如 ,以 下 就 是 武汉 大 
学 网 站 中 一 幅 新 闻 图 片 的 绝对 URL: 

http://news. whu. edu. cn/_mediafile/whu_news/2015/04/14/2ppgcrb9dk. jpg 

用 户 可 以 通过 如 下 代码 来 引用 它 : 

< img src = "http://news. whu. edu. cn/_mediafile/whu_news/2015/04/14/2ppgcrb9dk. jpg" /> 

相对 URL 用 于 引用 相对 于 使 用 URL 位 置 的 另 一 个 资源 ,所 以 当前 网 页 的 位 置 很 重要 。 
例如 , 若 当前 网 页 位 于 网 站 的 根 目录 ,该 网 页 中 的 如 下 代码 可 以 引用 网 站 的 Images 目录 中 的 
img4. bmp 文件 : 

< img src = "Images/img4.bmp " alt = "图 像 " /> 

若 当前 网 页 位 于 网 站 根 目录 的 Student 子 目录 中 ,该 网 页 中 的 如 下 代码 可 以 引用 网 站 的 
Images 目录 中 的 img4. bmp 文件 : 

< img src = "../Images/img4.bmp "alt = "图 像 " /> 

其 中 ,开头 的 两 个 句点 用 于 导航 到 网 站 根 目 录 。 

在 服务 器 端 可 以 用 波浪 符号 指向 网 站 根 目 录 。 例 如 ,该 网 站 的 任何 网 页 中 的 如 下 代码 都 
可 以 引用 网 站 的 Images 目录 中 的 img4. bmp 文件 : 
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< img src = "~ /Images/img4. bmp" /> 


注意 : Visual Studio 的 以 前 版 本 将 为 内 置 的 Web 服务 器 建立 一 个 应 用 程序 目录 ,所 以 必 
须 用 一 。 而 Visual Studio 2012 附带 的 新 的 IIS Express 默认 不 使 用 应 用 程序 目录 ,这 样 就 不 
再 认可 上 述 URL 表示 。 
【 例 3.8】 在 ch3 网 站 中 添加 一 个 WebForm8. html 网 页 ,其 功能 是 说 明 图 像 标 记 的 应 用 。 
解 : 其 步骤 如 下 。 
Q@ 打开 ch3 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch3” 对 话 框 ,在 中 间 列 表 中 
选择 “HTML 页 ” ,将 文件 名 称 改 为 WebForm8. html, 单 击 “ 添 加 ”按钮 。 
@ 在 解决 方案 资源 管理 器 中 右 击 网 站 名 ch3, 在 出 现 的 快捷 菜单 中 选择 “添加 | 新 建 目录 ” 
命令 ,添加 一 个 名 称 为 Images 的 目录 ,并 放 入 几 个 图 像 文件 。 
@ 进入 源 视图 ,设计 其 HTML 代码 如 下 : 
<!DOCTYPE html > 
<htm]l xmlns = "http://www.w3.org/1999/xhtml"> 
<head> 
<meta http - equiv= "Content ~ Type" content = "text/html; charset = utf- 8"/> 
<title > 第 3 章 例 3.8</title> 
</head> 
<body> 
< img src = "Images/imgl. bmp" alt = "图 像 1" width= "150" height = "150"/> 
< img src = "Images/img2. bmp" alt = "图 像 2" width= "100" height = "100"/> 


</body> 
</html > 
该 网 页 在 IE 浏览 器 中 的 显示 结果 如 图 3. 11 
所 示 , 其 中 采用 二 img> 标 记 显 示 两 幅 图 。 (DO[B re/eaorssr -0 
大 第 3 意 W3.8 x 加 加 


3.1.10 框架 标记 


框架 也 是 网 页 布局 的 重要 工具 , 它 与 表格 的 不 
同 之 处 在 于 表格 是 把 网 页 分 割 成 小 的 单元 格 ,而 框 
架 是 把 浏览 器 的 窗口 分 割 成 若干 个 小 窗口 ,这 些 子 
窗口 称 为 框架 ,每 一 个 框架 都 相当 于 一 个 浏览 器 窗 
口 , 这 样 就 使 一 个 浏览 器 窗口 可 以 显示 多 个 网 页 。 
主要 的 框架 标记 如 表 3.7 所 示 。 


表 3.7 主要 的 框架 标记 及 其 说 明 


图 3.11 WebForm8. html 网 页 的 显示 结果 


框架 标记 功 能 
=frame> 定义 框架 集 的 窗口 或 框架 
=frameset> 定义 框架 集 
noframes> 定义 针对 不 支持 框架 的 用 户 的 替代 内 容 
<iframe> 定义 内 联 框架 

1. 建立 框架 

基本 用 法 : 


<frameset 属性 = "属性 值 ">…</frameset > 
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其 功能 是 指定 当前 窗口 的 分 割 结构 , 即 分 为 几 行 还 是 分 为 几 列 。 框 架 标记 常用 的 属性 
0 rows 王 "高 度 列表 ": 设置 子 窗口 的 高 度 , 即 把 整个 窗口 横向 分 割 成 几 个 框架 (垂直 框 

。 i 设置 子 窗口 的 宽度 , 即 把 整个 窗口 纵向 分 割 成 几 个 框架 (水 平 框 

Pe 用 于 指定 列 。 例 如 要 把 当前 窗 
口 分 成 等 高 的 两 行 ,可 以 如 下 这 样 : 


<frameset rows = "50% ,50% ">…</frameset> 


“高 度 列表 ”( 或 “宽度 列表 ”中 的 数字 个 数 表 示 要 分 割 的 行 (或 列 ) 数 ,各 数字 的 大 小 表示 
相应 行 (或 列 ) 的 高 度 (或 宽度 ) ,其 对 应 顺序 为 从 上 到 下 (或 从 左 到 右 )。 各 数字 的 取 值 可 以 为 
具体 的 整数 值 ( 其 单位 为 像素 ) ,可 以 为 当前 窗口 高 度 (或 宽度 ) 的 百分数 。 其 中 ,在 列表 数字 中 
可 以 有 一 个 数字 被 指定 为 **”。 这 个 “x* ”表示 相应 的 行 高 (或 列 宽 ) 为 指定 了 其 他 行 (或 列 ) 的 
高 度 (或 宽度 ) 后 当前 窗口 剩余 的 高 度 (或 宽度 ) 。 

注意 : 在 同一 个 一 frameset 二 中 不 能 既 指 定 rows 又 指定 cols, 因 为 没有 足够 的 信息 提供 
给 浏览 器 在 分 行 后 应 该 在 哪 一 行 中 分 列 。 

2. frame 标记 

一 个 frame 表示 一 个 窗口 , 它 骨 入 在 一 frameset 二 … 一 /frameset 二 之 间 , 按 照 rows 和 
cols 设 定 的 子 窗口 顺序 依次 指定 一 个 子 窗口 显示 哪 一 个 网 页 。 其 基本 用 法 如 下 : 

<frame 属性 = "属性 值 ”… /> 


其 常用 的 属性 如 下 。 

。 src 一 "url" : 设置 要 链接 到 该 子 窗口 的 URL。 

。 name 一 "framename" : 表示 子 窗口 的 名 称 。 

。 marginwidth 一 "size" : 用 来 控制 显示 内 容 和 窗口 左右 边界 的 距离 ,默认 为 1 。 

。 marginheight 一 "size": 用 来 控制 显示 内 容 和 窗口 上 下 边界 的 距离 ,默认 为 1 。 

。 scrolling 一 "yes/no/auto" : 指定 子 窗 口 是 否 使 用 滚动 条 ,默认 为 auto, 即 根据 窗口 内 

容 决定 是 否 有 滚动 条 。 

。 noresize: 使 用 该 属性 后 ,指定 窗口 不 能 调整 窗口 大 小 。 

例如 ,以 下 代码 使 用 3 个 不 同 的 文档 制作 一 个 如 图 3. 12 所 示 的 水 平 框架 (其 中 
HtmlPagea. html 等 3 个 网 页 分 别 在 浏览 器 中 显示 “框架 A”“ 框 架 B” 和 "框架 C”) ， 


<frameset cols= "30% ,40% ,30%"> 
<frame src = "HtmlPagea. html"/> 
< frame src = "HtmlPageb. html1"/> 
<frame src = "HtmlPagec. html"/> 
</frameset > 


而 以 下 代码 使 用 3 个 不 同 的 文档 制作 一 个 如 图 3. 13 所 示 的 垂直 框架 : 


<frameset rows="30%,40%,30%"> 
<frame src = "HtmlPagea. html"/> 
< frame src = "HtmlPageb. html"/> 
< frame src = "HtmlPagec. html1"/> 
</frameset > 
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图 3.12 一 个 水 平 框架 图 3.13 一 个 垂直 框架 


【 例 3.9】 在 ch3 网 站 中 添加 一 个 WebForm9. html 网 页 ,其 功能 是 说 明 框 架 标记 的 
应 用 。 

解 : 其 步骤 如 下 。 

@ 打开 ch3 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch3” 对 话 框 , 在 中 间 列 表 中 
选择 “HTML 页 ”, 将 文件 名 称 改 为 WebForm9. html, 单 击 “ 添 加 ”按钮 。 

@ 进入 源 视图 ,设计 其 HTML 代码 如 下 : 


<!DOCTYPE html PUBLIC " - //W3C//DTD XHTML 1.0 Frameset//EN" 
"http://www. w3. org/TR/xhtml1/DTD/xhtml1 - frameset. dtd"> 
<html> 
<head> 
<meta http - equiv= "Content ~ Type" content = "text/html; charset = utf— 8"/> 
<title > 第 3 章 例 3.9 </title> 
</head> 
<frameset rows="*x,80%"> 
<frame src = "WebForm1.html" id = "fl"/> 
<frameset cols = "40% ,60% "> 
< frame src = "WebForm3. html" id = "f3"/> 
<frame src = "WebForm4.html" id = "f4"” scrolling= "no"/> 
</frameset > 
</frameset > 
</html > 


该 网 页 在 IE 浏览 器 中 的 显示 结果 如 图 3. 14 所 示 , 它 是 一 种 混合 框架 结构 。 有 关 框 架 网 
页 设计 的 几 点 说 明 如 下 : 


图 3.14 WebForm9. html 网 页 的 显示 结果 
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OD 由 于 HTML5 不 再 支持 frameset/frame, 而 只 有 XHTML1.0 的 框架 版 支持 frameset/ 


frame, 所 以 要 验证 包含 框架 的 页 面 ,需要 确保 DOCTYPE 被 设置 为 XHTML 1. 0 Frameset 
DTD, 即 


<!DOCTYPE html PUBLIC " - //W3C//DTD XHTML 1.0 Frameset//EN" 
"http://www. w3. org/TR/xhtml1/DTD/xhtml1 - frameset. dtd"> 


@ 元 素 frameset 不 能 幅 套 在 元 素 body 中 , 即 不 能 与 一 frameset 二 一 /frameset 二 标记 一 
起 使 用 二 body 二 二 /body 之 标记 。 


@ 在 XHTML 1.0 Frameset 中 ,name 属性 被 视 为 已 过 时 ,可 以 用 id 代替 ,但 Visual 
Studio 仅仅 给 出 警告 消息 ,网 页 仍然 能 够 正确 运行 。 

3. iframe 标记 

iframe 标记 用 于 创建 包含 另外 一 个 文档 的 内 联 框架 (即行 内 框架 )。 其 基本 用 法 如 下 

< iframe 属性 = "属性 值 "> … </iframe> 


iframe 框架 的 常用 属性 如 下 。 
。 src 二 "url": 设置 要 链接 到 该 框架 的 URL 。 
。 width 一 "size" : 设置 iframe 框架 的 宽度 。 
height 二 "size" : 设置 iframe 框架 的 高 度 。 
。 name 一 "name": 设置 iframe 框架 的 名 称 。 
。 frameborder 一 "size": 指定 iframe 框架 是 否 有 边框 ,size 可 取 1 和 0 值 之 一 ,默认 为 1。 
。 marginwidth 一 "size" : 用 来 控制 显示 内 容 和 窗口 左右 边界 的 距离 ,默认 为 1 。 
。 marginheight 一 "size": 用 来 控制 显示 内 容 和 窗口 上 下 边界 的 距离 ,默认 为 1 。 
。 scrolling 二 "yes/no/auto": 指定 子 窗 口 是 否 使 用 滚动 条 ,默认 为 auto, 即 根据 窗口 内 
容 决定 是 否 有 滚动 条 。 
【 例 3.10】 在 ch3 网 站 中 添加 一 个 WebForm10. html 网 页 .采用 iframe 框架 标记 实现 网 
页 导航 功能 。 
解 : 其 步骤 如 下 。 
a@ 打开 ch3 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch3” 对 话 框 ,在 中 间 列 表 中 
选择 “HTML 页 ”, 将 文件 名 称 改 为 WebForm10. html, 单 击 “ 添 加 ”按钮 。 
@ 进入 源 视图 ,设计 其 HTML 代码 如 下 : 


<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head> 
<meta http - equiv= "Content ~ Type" content = "text/htm1; charset = utf— 8"/> 
<title > 第 3 章 例 3. 10 </title> 


</head> 
<body> 
<table> 
< 
<td> 
<h2 > 导航 </h2> 
<a href = "WebForml. htm]l" target = "showframe"> WebForml </a> 
<br /> 


<a href = "WebForm2. htm]l"” target ="showframe"> WebForm2 </a> 
<br /> 
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<a href = "WebForm3. htm]" target = "showframe"> WebForm3 </a> 
</td> 
<td> 
< iframe name = "showframe"></iframe> 
</td> 
</tr> 
</table> 
</body> 
</html > 


该 网 页 中 有 一 个 1 行 2 列 的 表格 ,第 1 列 显示 3 个 超 链接 ,第 2 行 有 一 个 iframe 框架 (名 
称 为 showframe) 。 在 运行 该 网 页 时 ,用 户 单 击 任何 超 链 接 , 则 在 showframe 框架 中 显示 一 个 
网 页 。 用 户 单 击 WebForm2 超 链接 的 显示 结果 如 图 3. 15 所 示 。 


从 中 看 到 frameset/frame 和 iframe 框架 的 er 
几 点 差别 如 下 : (DO[B me/eehessss0mebrom P- cj 全 六 而 
。 HTML5 不 支持 frameset/frame, 但 支持 - 
iframe。 中 华人 民 共 和 国 
。 frame 不 能 脱离 frameset 单独 使 用 ,而 
i 中 华人 民 共 和 国 
iframe 可 以 。 
。 frame 的 高 度 只 能 通过 frameset 控制 ,而 


iframe 可 以 自己 控制 。 
frame 不 能 放 在 body 中 ,而 iframe 可 以 。 图 3.15 WebForm10. html 网 页 的 显示 结果 


iframe 的 使 用 更 加 随意 和 灵活 。 


3.1.11 表单 标记 

HTML 提供 的 表单 (form) 是 用 来 将 用 户 输 入 的 数据 从 浏览 器 传递 给 Web 服务 器 的 。 例 
如 可 以 利用 表单 建立 一 个 录入 界面 ,也 可 以 利用 表单 对 数据 库 进 行 查询 。 表 单 的 主要 标记 如 
表 3.8 所 示 。 


表 3.8 主要 的 表单 标记 及 其 说 明 


表单 标记 功 能 说 明 
=form> 定义 供用 户 输入 的 HTML 表单 
=input> 定义 输入 控件 
=textarea> 定义 多 行 的 文本 输入 控件 
=button> 定义 按钮 
到 select 二 定义 选择 列表 (下 拉 列 表 ) 
optgroup> 定义 选择 列表 中 相关 选项 的 组 合 
=option> 定义 选择 列表 中 的 选项 
<label> 定义 input 元 素 的 标注 
<fieldset> 定义 围绕 表单 中 元 素 的 边框 
<legend> 定义 fieldset 元 素 的 标题 
=datalist> 定义 下 拉 列 表 HTML5 新 增 标记 
keygen> 定义 生成 密 钥 HTML5 新 增 标记 


output> 定义 输出 的 一 些 类 型 HTML5 新 增 标记 
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1.， 志 form 二 标记 
基本 用 法 : 


<form 属性 = "属性 值 "> … </form> 


二 form 二 标记 的 主要 属性 如 下 。 
。 action( 必 选 ): 用 来 指出 当 这 个 表单 提交 后 需要 执行 的 驻 留 在 Web 服务 器 上 的 程序 名 
(包括 路 径 ) 是 什么 。 一 旦 Internet 网 络 用 户 提 交 输 入 信息 后 服务 器 便 激活 这 个 程序 ， 
完成 某 种 任务 。 例 如 二 form action 王 "login. aspx”method 一 "post" 二 … 一 /form 二 ， 
当 用 户 单 击 本 表单 的 提交 按钮 以 后 , Web 服务 器 上 的 login. aspx 将 接收 用 户 输入 的 信 
息 , 以 登记 用 户 信息 。 
method( 可 选 ): 用 来 说 明 从 客户 端 浏览 器 将 因特网 用 户 输入 的 信息 传送 给 Web 服务 
器 时 所 使 用 的 方式 , 它 有 两 种 方式 , 即 post 和 get( 默 认 方式 ), 前 者 从 指定 的 资源 请 求 
数据 ,后 者 向 指定 的 资源 提交 要 被 处 理 的 数据 。 从 数据 的 可 见 性 看 两 者 的 区 别 是 ,使 
用 post 时 表单 中 所 有 的 变量 及 其 值 按 规 律 放 入 报 文中 ,而 不 是 附加 在 action 所 设 定 
的 URL 之 后 ; 使 用 get 时 将 form 的 输入 信息 作为 字符 串 附 加 在 action 所 设 定 的 
URL 的 后 面 ,并 用 *?” 隔 开 , 即 在 客户 端 浏览 器 的 地 址 栏 中 可 以 直接 看 见 这 些 内 容 。 
enctype( 可 选 ): 该 属性 规定 在 发 送 到 服务 器 之 前 应 该 如 何 对 表单 数据 进行 编码 。 默 
认 情 况 下 ,表单 数据 会 编码 为 application/x-www-form-urlencoded。 也 就 是 说 ,在 发 
送 到 服务 器 之 前 ,所 有 字符 都 会 进行 编码 (空格 转换 为 "十 ?加 号 ,特殊 符号 转换 为 
ASCII 十 六 进 制 值 ) 。 

。 target( 可 选 ); 用 于 规定 在 哪 一 个 窗口 中 打开 action 属性 中 规定 的 网 页 ,默认 值 为 

“_self”。 

2. 各 种 常见 的 表单 控件 

在 二 form> 与 二 /form 之 之 间 可 以 嵌入 各 种 控件 ,也 称 为 表单 域 标记 。 它 们 的 通用 格 
式 为 : 

< input type= "输入 控件 类 型 " name = "域名 称 " value= " 值 "> 

其 中 ,type 属性 设置 该 控件 的 类 型 ,name 确定 该 控件 在 整个 文档 中 的 名 称 ,value 属性 设 
置 input 元 素 的 值 。 

(1) 单行 文本 输入 框 

基本 用 法 : 

< input type= "text" name = "域名 称 ”value = "默认 值 " maxlength= 值 size= 值 /> 

其 中 ,value 属性 确定 该 文本 框 预 置 的 文字 。maxlength 属性 确定 在 这 个 文本 框 中 所 能 容 
纳 的 字符 串 最 大 长 度 , 该 项 可 以 不 设 。size 属性 确定 这 个 文本 框 的 显示 宽度 ,以 能 显示 多 少 个 
字符 来 衡量 。 

另 有 一 种 特殊 的 单行 文本 输入 框 专门 用 于 输入 密码 (password) ,不 同 之 处 在 于 它 对 键盘 
输入 的 回 显 字符 为 “* ”, 即 它 把 用 户 的 输入 隐藏 了 。 其 用 法 为 : 

< input type = "password" name = "域名 称 ”value = "默认 值 " maxlength= 值 size = 值 > 

(2) 命令 按钮 

基本 用 法 : 
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< input type= "button" name = "域名 称 " value= " 值 "> 


type 设置 为 button 表示 这 个 控件 为 按钮 。 另 有 两 个 特殊 的 控件 ,它们 实质 上 是 按钮 ,但 
其 type 不 是 button, 而 分 别 是 submit( 提 交 按 钮 ) 和 reset( 重 置 按钮 ) 。 其 用 法 分 别 为 : 

< input type= "submit" name = "域名 称 " value = " 值 "> 

< input type= "reset" name = "域名 称 ”value = " 值 "> 

按 下 提交 按钮 后 ,表单 就 把 当前 所 获得 的 信息 以 method 指定 的 方式 全 部 传 给 action 指 
定 的 程序 。 按 下 重 置 按钮 后 , 则 表单 中 的 所 有 控件 都 被 重 置 ,恢复 初始 状态 。 

(3) 复 选 框 

基本 用 法 : 


< input type = "checkbox" name = "域名 称 " value = " 值 " checked> 


type 设置 为 checkbox 表示 这 个 控件 为 复 选 框 。value 用 于 设置 当 这 个 检查 框 被 选中 后 发 
送 给 action 指定 处 理 程序 的 值 。checked 为 预 置 该 检查 框 被 选中 ,如 果 有 这 一 项 ,该 检查 框 初 
始 值 为 被 选中 。 

(4) 单 选 框 (选项 按钮 ) 

基本 用 法 : 

< input type= "radio" name = "域名 称 " value = " 值 " checked> 

单 选 框 的 各 属性 意义 与 复 选 框 的 基本 相同 。 值 得 注意 的 是 ,要 设置 单 选 框 时 ,各 选项 必须 
同名 (具有 相同 的 name) , 取 值 不 同 (value 不 相同 ) ,并 且 几 个 选项 中 必须 有 且 只 能 有 一 个 预 置 
为 选中 。 如 果 没 有 预 置 选中 项 ,默认 预 置 第 一 个 选择 项 被 选中 。 

(5) 图 像 

基本 用 法 : 

< input type = "image" name = "域名 称 " src = URL > 


该 标记 把 src 指定 位 置 的 图 像 加 到 表单 里 , 当 用 户 用 鼠标 在 该 图 像 内 单 击 时 ,该 点 在 图 像 
中 的 坐标 将 作为 值 传 给 action 指定 的 处 理 程序 。 

(6) 隐藏 项 

基本 用 法 : 

< input type = "hidden" name = "域名 称 ”value = 值 > 


该 控件 的 内 容 在 表单 中 被 隐藏 起 来 ,并 不 在 网 页 中 显示 。 通 常 可 用 来 以 隐藏 方式 向 服务 
器 传送 有 关 信息 。 

【 例 3.11】 在 ch3 网 站 中 添加 一 个 WebForml1. html 网 页 ,通过 一 个 用 户 注 册 界 面 的 设 
计 说 明 表 单 标记 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch3 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 * 添 加 新 项 -ch3? 对 话 框 ,在 中 间 列 表 中 
选择 “HTML 页 ”, 将 文件 名 称 改 为 WebForm11. html, 单 击 “ 添 加 ”按钮 。 

@ 进入 源 视图 ,设计 其 HTML 代码 如 下 : 

<!DOCTYPE html > 


<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head> 
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<meta http - equiv= "Content — Type" content = "text/htm1; charset = utf — 8"/> 
<title > 第 3 章 例 3.11</title> 
</head> 
<body> 
< form action = "RegPage. html" method= "post"> 
<table style= "align ~ content :center;width:350px"> 
<caption><h3 > 用 户 注 册 </h3 ></caption > 
<tr> 
<td style = "text - align:right"> 用 户 名 </td> 
<td> < input type = "text" name = "name" size = "20" 
style = "width: 120px; height: 16px" /> 
</td> 
</tr> 
<tr> 
<td style= "text- align:right"> 密 码 </td> 
<td> 
< input type = "password" name = "pass" size= "20" 
style = "width: 120px; height: 16px" /> 
</td> 
</tr> 
<tr> 
<td style = "text - align:right"> 年 龄 </td> 
<“td>< input type = "radio" name = "age" /> 18 以 下 
< input type = "radio" name = "age" /> 18 - 25 
<br /> 
< input type = "radio" name = "age" /> 26 - 45 
< input type = "radio" name = "age" /> 45 以 上 
</td> 
</tr> 
<tr> 
<td style = "text - align:right"> 喜 爱 的 运动 </td> 
<td> < input type = "checkbox" name = "lovel" value = "足球 "人 > 足球 
<br /> 
< input type = "checkbox" name = "love2" value = "篮球 "checked = "checked" /> 篮球 
<br />< input type = "checkbox" name = "love3" value = "排球 "/> 排 球 
</td> 
</tr> 
<tr> 
<td style= "text ~ align:center" colspan= "2"> 
< input type = "submit”value = "确定 " /> gnbsp;&nbsp; gnbsp; 
<input type = "reset" value= " 重 置 " /> 
</td> 
</tr> 
</table> 
</form> 
</body > 
</html > 


该 网 页 在 下 浏览 器 中 显示 的 初始 界面 如 图 3. 16 所 示 。 用 户 在 其 中 操作 后 单 击 “ 确 定 ” 按 
钮 ,将 转向 RegPage. html 网 页 (这 里 没有 设计 RegPage. html 网 页 ) 。 
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喜爱 的 运动 回复 球 
口 排球 


图 3.16 WebForml1. html 网 页 的 显示 结果 


3.2 CSS 


级 联 样式 表 或 层 释 样式 表 (Cascading Style Sheets,CSS) 与 HTML 一 样 也 是 一 种 标记 语言 ， 
甚至 很 多 属性 都 是 来 源 于 HTML。CSS 有 助 于 为 HTML 文档 提供 美观 且 一 致 的 外 观 。 通 过 使 
用 样式 ,可 以 简化 HTML 网 页 标记 设计 ,同时 使 网 页 外 观 不 再 只 由 浏览 器 决定 ,网 页 设计 者 也 可 
以 精确 地 控制 HTML 标记 在 浏览 器 中 的 外 观 , 如 网 页 布局 .字体 .颜色 .背景 和 其 他 效果 。 


3.2.1 CSS 和 CSS3 


HTML 标记 原本 被 设计 为 用 于 定义 文档 内 容 。 通 过 使 用 二 hl 二 、 二 p 二 二 table 二 这 样 
的 标记 ,HTML 的 初 囊 是 表达 “这 是 标题 "“ 这 是 段落 "“ 这 是 表格 "之 类 的 信息 。 同 时 文档 布 
局 由 浏览 器 完成 ,而 不 使 用 任何 的 格式 化 标签 。 

由 于 两 种 主要 的 浏览 器 (Netscape 和 IE) 不 断 地 将 新 的 HTML 标记 和 属性 添加 HTML 
规范 中 ,创建 文档 内 容 清晰 地 独立 于 文档 表现 层 的 网 站 变 得 越 来 越 困 难 。 为 了 解决 这 个 问题 ， 
W3C 肩负 起 了 HTML 标准 化 的 使 命 ,并 在 HTML 4. 0 之 外 创造 出 样式 (style) 。 这 便 是 CSS 
的 由 来 ,主要 目的 是 用 于 控制 网 页 的 样式 和 布局 。 所 有 的 主流 浏览 器 均 支 持 CSS。 

CSS 的 优点 是 提供 了 一 种 能 使 所 有 Web 网 页 样式 保持 一 致 的 方法 ,样式 信息 独立 于 网 页 
内 容 , 只 修改 一 个 样式 文件 就 可 以 改变 页 数 不 定 的 网 页 的 外 观 和 格式 ,版 面 和 页 面 布局 控制 能 
力 更 强 , 具 有 更 快 的 下 载 速度 。 

同 HTML 的 发 展 一 样 ,CSS3 是 最 新 的 CSS 标准 。CSS3 完全 向 后 兼容 ,因此 不 必 改 变现 
有 的 设计 。CSS3 被 划分 为 模块 ,其 中 最 重要 的 CSS3 模块 包括 选择 器 、 框 模型 .背景 和 边框 、 
文本 效果 、2D/3D 转换 动画、 多 列 布局 和 用 户 界 面 等 。 本 章 主要 介绍 选择 器 和 框 模型 。 

说 明 : CSS 在 Web 开发 中 非常 普遍 ,所 以 HTML5 规范 废弃 了 一 些 过 去 表示 样式 的 
HTML 元 素 , 如 font、center 和 strike 元 素 等 ,而 采用 相应 的 CSS 实现 同样 的 功能 。 


3.2.2 样式 表 


样式 是 指 每 一 个 网 页 元 素 呈 现在 浏览 器 中 的 风格 ,比如 字体 的 大 小 、 颜 色 , 页 面 的 背景 色 、 
背景 图 等 。 样 式 表 中 包含 应 用 于 网 页 元 素 的 相关 样式 信息 。 


69 
第 3 章 使 用 ASP.NET 进行 HTMLS 和 CSS3 设 


定义 样式 的 基本 格式 如 下 : 

样式 属性 1: 值 1; 样 式 属性 2: 值 2; … 

样式 属性 与 值 之 间 用 冒号 ": "分隔, 如 果 一 个 样式 中 有 多 个 样式 属性 ,各 样式 属性 之 间 要 
用 分 号 “;” 隔 开 。 

例如 ,一 个 最 简单 的 样式 表 的 形式 如 图 3. 17 所 示 。 其 中 ,hl 称 为 选择 器 ,用 来 表示 应 当 
向 什么 元 素 应 用 该 格式 化 信息 。 从 hl 开始 到 闭合 花 括号 的 代码 块 称 为 规则 。 上 述 规 则 定义 
了 网 页 中 所 有 二 hl 二 > 元素 的 外 观 。 该 选择 器 可 以 直接 映射 到 HTML 元 素 上 。 

一 般 情况 下 ,要 能 够 样式 化 网 页 上 的 元 素 ， 


浏览 器 必须 知道 3 件 事件 : pe Al etd at, 
。 必须 样式 化 网 页 上 的 什么 元 素 ? { color :green; 规 
必须 样式 化 元 素 的 什么 部 分 ? Re 
样子 ? | 
这 些 问题 的 答案 由 选择 器 .属性 和 值 给 出 。 图 3.17 最 简单 样式 表 的 形式 
1. CSS 选择 器 


在 CSS 中 ,选择 器 是 一 种 模式 ,用 于 选择 需要 添加 样式 的 元 素 。CSS 中 的 选择 器 有 
Universal 选择 器 .Type 选择 器 .类 选择 器 ID 选择 器 和 伪 类 选择 器 等 。 

(1) Universal 选择 器 

Universal 选择 器 (通用 选择 器 ) 用 星 号 (* ) 表 示 , 它 适用 于 网 页 的 所 有 元 素 。Universal 
选择 器 可 以 用 来 进行 一 些 全 局 设置 。 例 如 ,以 下 规则 将 网 页 中 所 有 元 素 的 字体 改 为 Arial: 

x* {font—family : Arial; } 

(2) Type 选择 器 

Type 选择 器 (类 型 选择 器 ) 是 最 典型 的 选择 器 类 型 ,用 于 指向 一 个 特定 类 型 的 HTML 元 
素 。 如 果 有 多 个 不 同 的 标记 要 使 用 相同 的 样式 , 则 可 以 采用 编组 的 方法 简化 定义 。 例 如 : 

hl, h2,h3 { color:red } 


则 所 有 的 hl、h2、h3 标题 都 将 以 红色 显示 ,在 这 种 表示 法 中 ,各 选择 器 之 间 要 用 逗号 ”,” 分 隔 。 
(3) 类 选择 器 
使 用 类 选择 器 可 以 为 某 一 个 HTML 标记 创建 多 个 样式 ,或 者 为 多 个 标记 创建 同一 种 样 
式 。 类 选择 器 的 定义 格式 如 下 : 
样式 定义 选择 符 . 类 名 {样式 属性 1: 值 1; 样 式 属性 2: 值 2; …} 
例如 ,hl. first 和 hl. second 的 样式 代码 分 别 如 下 : 


hl. first {color:red;font ~- size:40px } 
hl. second{color:blue; font — size:30px } 


这 样 ,可 以 通过 以 下 方式 使 用 它们 : 


<body> 
<hl class = "first"> 中 华人 民 共 和 国 </hl > 
<hl class = "second"> 教 育 部 </hl > 
</body > 
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其 在 浏览 器 中 的 显示 结果 如 图 3. 18 所 示 。 


(4) ID 选择 器 
中 华人 民 共 和 国 选择 器 用 来 在 网 页 内 选择 或 指向 一 个 或 多 个 特定 的 元 


教育 部 素 , 以 对 要 格式 化 的 元 素 进行 更 细 化 的 控制 。 用 户 可 以 使 用 
图 3.18 采用 类 选择 器 样式 的 ”若干 个 不 同 的 选择 器 ,这 里 仅 介绍 ID 选择 器 。 
浏览 器 显示 结果 ID 选择 器 以 “# ”为 标志 ,依靠 这 个 唯一 的 标志 可 以 定义 


一 套 样 式 。 其 定义 方法 如 下 : 
间 卫 选择 器 名 {属性 1: 值 1; 属性 2: 值 2; …; 属 性 n: 值 n} 
其 中 ,ID 选择 器 名 前 的 “# ”符号 不 能 省 略 。 例 如 : 


井 customIdl { color:red } 


在 网 页 中 引用 该 样式 的 标记 内 使 用 id 属性 即 可 ,例如 : 
<p id = "customId1"> 本 段落 文字 为 红色 </p> 


ID 选择 器 与 类 选择 器 的 主要 区 别 如 下 : 
。 类 选择 器 前 面 以 “. ”开始 ,而 ID 选择 器 前 面 以 “# ”开始 。 
。 在 设计 网 页 时 ,类 可 以 分 配给 任何 个 数 的 元 素 ,通常 ID 选择 器 只 能 在 某 个 HTML 文 
档 中 使 用 一 次 。ID 选择 器 类 似 于 表单 元 素 input 中 的 name 属性 ,每 个 name 属性 的 
值 应 该 是 唯一 的 。 
值得 注意 的 是 ,实际 上 有 些 浏览 器 (如 IE) 不 一 定 会 检查 网 页 中 ID 选择 器 的 唯一 性 ,可 
以 在 网 页 中 对 多 个 元 素 使 用 同一 个 ID 选择 器 ,从 而 使 同一 个 样式 表现 在 多 个 元 素 上 ， 
建议 最 好 不 要 这 么 做 。 

。 ID 选择 器 对 元 素 应 用 样式 时 比 类 选择 器 具有 更 高 的 优先 级 。 

(5) 伪 类 选择 器 

CSS 还 包含 一 系列 伪 类 选择 器 (简称 伪 类 ) ,在 创建 样式 规则 时 提供 了 额外 的 选项 。 伪 类 
可 以 添加 到 其 他 选择 器 ,以 创建 更 复杂 的 CSS 规则 。 

例如 ,有 以 下 代码 : 

#title p:first ~ child { font ~ size: small; color:red; } 

#title p:nth— child(2) { font — size: medium; color:blue;} 

第 1 行 表示 将 该 样式 应 用 于 id 属性 为 title 的 元 素 中 的 第 一 个 段落 标记 ,第 2 行 表 示 将 该 
样式 应 用 于 id 属性 为 title 的 元 素 中 的 第 2 个 段落 标记 。 对 于 如 下 HTML 代码 : 


<body> 
<div id= "title"> 
<p> 第 1 个 段落 : 红色 small </p> 
<p> 第 2 个 段落 : 蓝 色 medium </p> 
</div> 
</body> 
其 在 浏览 器 中 的 显示 结果 如 图 3. 19 所 示 。 第 1 个 段落 : 红色 small 
另外 还 有 与 错 点 相关 的 伪 类 , 即 专用 于 <a 二 标记 的 选择 第 2 个 段落 ， 蓝 色 mediam 
器 ,可 以 设置 不 同类 型 超 链 接 的 显示 方式 。 四 
，a:link: 未 被 访问 过 的 超 链接 。 0 
。 al:visited: 已 被 访问 过 的 超 链接 。 时 名 显 不 持 


71 
第 3 章 使 用 ASP.NET 进行 HTMLS 和 CSS3 设 | 


"al:active: 当 超 链接 处 于 选中 状态 。 

。a:hover: 当 鼠 标 指针 移动 到 超 链 接 上 。 

例如 ， 

a:visited,a:link { color:blue } 

a:hover { color:red; text - decoration:none } 

上 述 语句 定义 了 这 个 文档 中 的 超 链 接 文本 在 未 访问 和 被 访问 时 为 蓝 色 、 带 下 划 线 , 当 有 鼠 
标 指针 掠 过 时 颜色 变 为 红色 、 不 带 下 划 线 。 

2. CSS 属性 

属性 是 元 素 的 一 部 分 ,可 通过 样式 表 修 改 。CSS 定义 了 一 个 很 长 的 属性 列表 ,包括 CSS 
文本 属性 (Text) .CSS 背景 属性 (Background) CSS 尺寸 属性 (Dimension) 和 CSS 表格 属性 
CTable) 等 。 在 大 多 数 情况 下 网 站 中 不 会 用 到 所 有 项 , 表 3.9 给 出 了 常用 的 CSS 属性 。 


表 3.9 常用 的 CSS 属性 


CSS 属性 功 能 
background-color 设置 元 素 的 背景 颜色 
background-image 设置 元 素 的 背景 图 像 
border 在 一 个 声明 中 设置 所 有 的 边框 属性 
height 设置 元 素 的 高 度 
width 设置 元 素 的 宽度 
font 在 一 个 声明 中 设置 所 有 字体 属性 
font-family 规定 文本 的 字体 系列 
font-size 规定 文本 的 字体 尺寸 
font-weight 规定 字体 的 粗细 
target 简写 属性 ,设置 target-name ,target-new 以 及 target-position 属性 
margin 在 一 个 声明 中 设置 所 有 外 边 距 属性 
padding 在 一 个 声明 中 设置 所 有 内 边 距 属性 
color 设置 文本 的 颜色 
text-align 规定 文本 的 水 平 对 齐 方 式 


除 此 之 外 还 有 两 个 很 重要 的 定位 属性 。 

1) float 属性 

该 属性 定义 元 素 在 哪个 方向 浮动 。 以 往 这 个 属性 总 是 应 用 于 图 像 ,使 文本 围绕 在 图 像 周 
围 ,不 过 在 CSS 中 任何 元 素 都 可 以 浮动 ,浮动 元 素 会 生成 一 个 块 级 框 ,而 不 论 它 本 身 是 何 种 元 
素 。 该 属性 可 能 的 取 值 如 下 。 

。 none( 默 认 值 ) : 元 素 不 浮动 ,并 会 显示 在 其 在 文本 中 出 现 的 位 置 。 

。 left: 元 素 向 左 浮动 。 

。 right: 元 素 向 右 浮动 。 

。 inherit: 规定 应 该 从 父 元 素 继承 float 属性 的 值 。 

2) position 属性 

该 属性 规定 元 素 的 定位 类 型 , 它 定义 建立 元 素 布局 所 用 的 定位 机 制 。 任 何 元 素 都 可 以 定 
位 ,不 过 绝对 或 固定 元 素 会 生成 一 个 块 级 框 ,而 不 论 该 元 素 本 身 是 什么 类 型 。 相 对 定位 元 素 会 
相对 于 它 在 正常 流 中 的 默认 位 置 偏 移 。 其 可 能 的 取 值 如 下 。 

。 static( 默 认 值 ): 没有 定位 ,元 素 出 现在 正常 的 流 中 (忽略 top、bottom.left 或 right 等 声明 )。 

。 absolute: 生成 绝对 定位 的 元 素 , 相 对 于 static 定位 以 外 的 第 一 个 父 元 素 进 行 定位 。 元 
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素 的 位 置 通过 left、top、right 或 bottom 属性 进行 规定 。 
。 fixed: 生成 绝对 定位 的 元 素 , 相 对 于 浏览 器 窗口 进行 定位 。 元 素 的 位 置 通过 left、top、 
right 或 bottom 属性 进行 规定 。 
。 relative: 生成 相对 定位 的 元 素 ,相对 于 其 正常 位 置 进行 定位 。 因 此 ,left:20px 会 向 元 
素 的 左边 位 置 添加 20 像素 。 
。 inherit; 规定 应 该 从 父 元 素 继承 position 属性 的 值 。 
例如 ,以 下 代码 采用 绝对 定位 和 相对 定位 显示 文字 。 
<body > 
<div style = "position:absolute; left:40px; top:60px"> 
<h2 > 绝对 定位 的 标题 </h2 > 
</div> 
<div style= "position: relative: left:20px"> 
<h3> 相 对 定位 的 标题 </h3> 
</div> 
</body> 
其 显示 结果 如 图 3. 20 所 示 。 
实际 上 ,Visual Studio 提供 了 十 分 方便 的 智能 感知 , 当 开发 人 员 输 入 CSS 属性 名 时 ,智能 
感知 便 列 出 相应 的 CSS 属性 ,如 图 3. 21 所 示 , 用 户 可 以 从 中 选择 相应 CSS 属性 。 


(HO 避 htpi//localhost5147 DD- © 
Elocalhost x 国 有 syle "vidth: Opx he 75 


2 font-: is 
相对 定位 的 标题 ^ 2 
站 加 line-height 
绝对 定位 的 标题 @ max-height 
i 
图 3.20 采用 绝对 定位 和 相对 定位 显示 文字 的 结果 图 3.21 智能 感知 显示 的 CSS 属性 
3. 属性 值 


从 前 面 的 float 和 position 属性 看 到 ,同一 属性 的 不 同 取 值 会 导致 不 同 的 效果 。 

另外 ,与 属性 一 样 , 值 也 有 很 多 风格 ,可 用 的 值 取决 于 具体 的 属性 。 例 如 ,color 属性 采用 
表示 颜色 的 值 ,可 以 是 颜色 名 称 ( 如 red), 也 可 能 是 代表 红 、 绿 、 蓝 色 成 分 的 十 六 进 制 数 (如 
# FFO000)。 

同样 , 当 开 发 人 员 输 入 完 一 个 CSS 属性 名 时 ,智能 感知 便 列 出 相应 的 CSS 属性 值 ,如 
图 3. 22 所 示 列 出 的 是 color 的 CSS 属性 值 ,用 户 可 以 从 中 选择 相应 值 。 


style=" width: 0px: color: 人 ”73 


* 国 | 加 加 加 本 本 可 


图 3.22 智能 感知 显示 的 CSS 属性 值 


3.2.3 样式 表 的 组 织 方式 


样式 表 的 组 织 方式 主要 有 3 种 , 即 内 联 样式 、 内 部 样式 表 和 外 部 样式 表 。 无 论 CSS 样式 
如 何 组 织 , 一 旦 服务 器 将 它们 发 送 到 客户 端 ,浏览 器 将 负责 解析 样式 ,把 它们 应 用 于 网 页 中 相 
应 的 HTML 元 素 。 而 当 采 用 内 部 样式 表 或 外 部 样式 表 时 ,样式 被 定义 为 CSS 规则 ,浏览 器 使 
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用 该 规则 确定 应 用 什么 样式 ,以 及 应 用 于 哪些 HTML 元 素 。 

1. 内 联 样式 

在 网 页 设计 中 ,大 多 数 HTML 元 素 都 有 style 属性 ,每 个 HTML 元 素 使 用 二 style 二 标记 
建立 一 个 或 多 个 样式 ,这 种 方式 就 是 内 联 样式 方式 ,也 称 为 网 页 内 榜 法 。 其 用 法 如 下 : 

style= "属性 1: 值 1; 属 性 2: 值 2; … ;属性 n: 值 a" 

在 前 面 例 3.4 中 的 如 下 代码 就 是 采用 这 种 方式 : 


<table border = "1" style= "text ~ align:center;width:300px; border:double"> 


内 联 样式 不 需要 定义 为 规则 ,因为 它们 会 自动 应 用 于 包含 它们 的 元 素 。 因 此 ,浏览 器 不 需 
要 选择 要 应 用 该 样式 的 元 素 。 例 如 ( 粗 体 部 分 为 style 属性 设置 ) : 
<hl style= "font - size:40px; color:Red; "> 中 华人 民 共 和 国 </hl > 
<h2 style= "font - size:30px; color:Blue; "> 教育 部 </h2 > 
内 联 样式 
这 样 ,浏览 器 直接 将 style 属性 指定 的 样式 作用 于 各 自 的 元 素 。 
这 种 方式 的 优点 是 直观 ,方便 ,缺点 是 若 不 喜欢 某 种 样式 ,需要 不 厌 其 烦 地 逐一 修改 每 一 
个 元 素 的 样式 。 
2. 内 部 样式 表 
设计 一 个 网 页 可 能 需要 多 个 样式 ,内 部 样式 表 方 式 就 是 将 在 单个 网 页 中 用 到 的 样式 集中 
存储 在 该 网 页 内 部 。 内 部 样式 表 就 是 单个 网 页 内 部 存储 的 CSS 样式 集合 (也 称 为 私有 样式 )。 
这 些 样式 位 于 二 style 二 标记 中 ,这 个 标记 一 般 位 于 网 页 的 二 head 二 部 分 。 
例如 ( 粗 体 部 分 为 style 标记 ): 
<!DOCTYPE html > 
<html xmlns = "http://www. w3.org/1999/xhtml"> 
<head > 
<meta http - equiv= "Content ~ Type" content = "text/htm1; charset = utf- 8"/> 
<title > 样式 引用 示例 </title> 
< style type = "text/css"> 1 
hl {font - size:40px; color:Red; } ,内 部 样式 表 
h2 {font - size:30px; color:Blue;} / 
</style> 
</head> 
<body> 
<hl> 中 华人 民 共 和 国 </hi > 
<h2 > 教育 部 </h2 > 
</body> 
</html > 
这 种 方法 的 优点 是 所 有 样式 集中 放 在 一 起 ,便于 修改 ,一 旦 某 个 样式 发 生 改变 ,本 网 页 中 
所 有 该 样式 的 元 素 都 会 发 生 更 改 。 
3. 外 部 样式 表 
前 面 两 种 方式 设计 的 样式 都 只 适用 于 它 所 在 的 网 页 。 如 果 要 将 其 用 于 其 他 网 页 ,最 好 把 
所 设计 的 样式 放 在 一 个 独立 的 文件 中 ,这 样 的 文件 就 是 外 部 样式 表 文 件 。 例 如 ,样式 表 文 件 
StyleSheetl. css 的 内 容 为 : 
body { background - color: 井 33bb66; } 
hl { font - size:40pt; color:Blue; } 
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h2 { font— size:30pt; color:White;} 


在 网 页 文件 中 引用 该 样式 表 文 件 只 需要 在 网 页 的 二 head 二 元 素 中 添加 如 下 代码 : 


<1link href = "StyleSheetl1.css" type = "text/css" rel = "Stylesheet" /> 


其 中 ,rel 规定 了 被 链接 文件 的 关系 , 取 值 是 Stylesheet, type 属性 规定 了 链接 文件 的 类 
型 ; href 属性 则 指定 了 要 链接 的 样式 表 文 件 的 URL。 

凡是 在 网 页 的 一 head 之 元 素 中 与 该 样式 表 文 件 建立 链接 的 HTML 文件 ,其 网 页 元 素 的 
样式 就 会 按照 外 部 样式 表 文 件 中 的 定义 显示 。 

外 部 样式 表 文 件 的 扩展 名 为 .css。 在 Visual Studio 中 ,创建 外 部 样式 表 文 件 的 操作 是 选 
择 “ 网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 ”对 话 框 ,在 中 间 列 表 中 选择 “样式 表 ” ,设置 样式 表 文 
件 名 ,然后 单 击 “ 添 加 ”按钮 。 

说 明 : 在 3 种 样式 表 组 织 方式 中 ,通常 ,外 部 样式 表 优 于 内 部 样式 表 , 而 内 部 样式 表 优 于 
内 联 样 式 。 但 在 实际 应 用 中 ,究竟 采用 哪 种 方式 需要 根据 具体 应 用 而 定 。 

4. 使 用 样式 生成 器 设计 样式 

Visual Studio 提供 了 专门 的 样式 生成 器 ,可 以 可 视 化 地 设计 样式 表 文 件 。 下 面 通过 一 个 
例子 说 明 样式 生成 器 的 使 用 方法 。 

【 例 3.12】〗 在 ch3 网 站 中 添加 一 个 WebForm12. html 网 页 ,然后 添加 一 个 StyleSheet. css 外 
部 样式 表 文 件 ,设计 相应 的 样式 ,并 将 其 应 用 到 网 页 设计 中 。 

解 : 其 步骤 如 下 。 

@ 打开 ch3 网 站 ,选择 “网 站 | 添加 新 项 "命令 ,出 现 “ 添 加 新 项 -ch3” 对 话 框 , 在 中 间 列 表 中 
选择 “HTML 页 ” ,将 文件 名 改 为 WebForm/2. html, 单 击 “ 添 加 ”按钮 。 

@ 选择 “网 站 | 添加 新 项 命令, 出现“ 添加 新 项 -ch3” 对 话 框 ,在 中 间 列 表 中 选择 “样式 
表 ”, 保 持 默 认 文件 名 为 Style Sheet. CSS, 单 击 “ 添 加 ”按钮 。 

@ 出 现 如 图 3. 23 所 示 的 样式 设计 界面 。 在 样式 编辑 窗口 中 删除 原 有 内 容 , 输 入 
“hl {  ) ”然后 将 光标 移动 到 该 花 括号 内 , 单 击 工 具 栏 中 的 委 按钮 (或 者 在 该 花 括号 内 右 击 ， 
在 出 现 的 快捷 菜单 中 选择 “生成 样式 "命令 ) .出现 "修改 样式 ?对 话 框 。 


DO localhost 51473 - Microsoft Visual sudiofE) 快速 已 动 (Ctrl+Q) Pl HX 
文件 中 将。 视图 。 网 站 (S) 生成 (8) 。 调 (D) EA(M) 工具 测 二 S) 分 析 (N) 窗口 IW) 帮助 (H) 

和 4 名 因 | 并 开 -| 

©-9O 间 - 知 国 由 PD-C- PintemetExplorer- Debug - 用; 


工具 和 梢 9x WebForml2.html 
搜索 工具 梢 记 - 9body { 
四 


图 3.23 样式 设计 界面 
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@ 在 “修改 样式 ”对 话 框 中 设置 hl 的 “字体 ”类 别 如 图 3. 24 所 示 , 单 击 “ 确 定 ” 按 钮 返回 。 
此 时 ,hl 的 定义 变 为 : 


hl { color: #FF0000; font - weight: bold; 
font - size: larger; font -family: 楷体 ; 
} 


font-family: 


font-size; text-decoration; 

加 waerline 
一 overline 

Eont-style: ed 


font-weight; 


Eont-varisnt: 回 wim 
text-transform: 回 >one 


eolor: 


微软 让 越 AaBbCc 


eolor: #7F0000; font-weight; bold; font-size, larger; font-fanily; 模 体 


图 3. 24 “修改 样式 "对话 框 


@ 采用 同样 的 操作 创建 两 个 类 选择 器 如 下 : 


hl. first { font ~ size: 35px; color: 间 0000FF; } 
hl. second { font - size: 25px; color: #006600; } 


单 击 工 具 栏 中 的 量 按 钮 保存 该 外 部 样式 表 文 件 。 
@ 切换 到 WebForml12. html 网 页 ,进入 源 视 图 ,设计 其 HTML 代码 如 下 : 


<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head> 
<meta http - equiv= "Content ~ Type" content = "text/html; charset = utf— 8"/> 
<title > 第 3 章 例 3.12 </title> 
< link href = "StyleSheet.css" type = "text/css" rel = "Stylesheet" /> 
</head> 
<body> 
<div> 
<hl > 中 华人 民 共 和 国 </hl > 
<hl class = "first"> 中 华人 民 共 和 国 </hl > 
<hl class = "second"> 中 华人 民 共 和 国 </hl > 
</div> 
</body > 
</html > 


该 网 页 在 I 下 浏览 器 中 的 显示 结果 如 图 3. 25 所 示 。 从 中 看 到 ,第 1 行文 字 应 用 了 hl 样 
式 , 第 2 行文 字 应 用 了 hl. first 类 样式 .第 3 行文 字 应 用 了 hl. second 类 样式 , 且 后 两 行 都 应 
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用 了 hl 的 加 粗 和 楷体 。 

该 样式 表 文 件 可 以 被 本 网 站 中 的 多 个 网 页 所 引用 ,以 达到 样式 共享 的 目的 ,而 且 使 整个 网 
站 界面 具有 一 致 性 。 

在 网 页 设计 中 选择 “视图 | 管理 样式 ”命令 ,会 出 现 “管理 样式 ”对 话 框 。 如 图 3. 26 所 示 的 
是 WebForm12. html 网 页 的 “管理 样式 ”对 话 框 ,通过 该 对 话 框 可 以 查看 当前 网 页 上 能 使 用 的 
所 有 样式 ,其 中 的 日 按钮 用 于 新 建 样式 ,用 按钮 用 于 附加 样式 表 。 


®S 多 htpy/iocalhost6380 pro 
局 第 3 齐全 3.12 "| 


中 华人 民 共 和 国 


图 3.25 WebForm12. html 网 页 的 显示 结果 图 3.26 “管理 样式 "对话 框 


3.2.4 CSS 方 框 模型 


在 CSS 中 , 方 框 模型 是 定位 元 素 的 核心 , 它 定义 了 浏览 器 如 何 把 HTML 中 的 每 个 元 素 看 
作 拢 形 方 框 。 该 方 框 由 不 同 的 部 分 组 成 ,包括 页 边 距 ,内 边 距 边框 和 内 容 , 如 图 3. 27 所 示 。 


内 边 距 (padding) 


上 
上 
上 
1 
1 
1 height 内 容 (HTML 元 素 ) 
1 
1 
上 
1 
上 
1 
上 


外 边 距 (margin) 


图 3.27 CSS 方 框 结 构 


1. 设置 方 框 的 外 边 距 
CSS 的 外 边 距 属性 设置 为 : 


margin: margin ~ top margin ~ right margin ~ bottom margin— left 

其 中 ,margin 设置 对 象 与 浏览 器 边框 之 间 的 边 距 ,margin-left 设置 左边 距 ,margin-right 
设置 右边 距 ,margin-top 设置 上 边 距 ,margin-bottom 设置 下 边 距 。 用 户 可 以 使 用 其 中 任何 一 
个 属性 只 设置 相应 的 外 边 距 ,而 不 会 直接 影响 所 有 其 他 外 边 距 。 
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例如 ,以 下 代码 指定 段落 的 左 外 边 距 为 2cm: 


<style type= "text/css"> 
pb. leftmargin {margin— left: 2cnm} 
</style> 
2. 设置 方 框 的 边框 
每 个 边框 有 3 个 方面 的 信息 , 即 宽度 、 样 式 以 及 颜色 。 
通过 border-width 属性 为 边框 指定 宽度 。 其 一 般 格式 为 : 


border - width: border - top— width border ~ right - width border - bottom — width border - left — width 
可 以 使 用 其 中 任何 一 个 属性 只 设置 相应 边 的 宽度 ,而 不 会 直接 影响 其 他 边 的 宽度 。 
通过 border-style 属性 为 边框 指定 样式 。 其 一 般 格式 为 : 


border - style: border — top— style border - right — style border - bottom— style border — left — style 


可 以 使 用 其 中 任何 一 个 属性 只 设置 相应 边 的 样式 ,而 不 会 直接 影响 其 他 边 的 样式 。 
通过 border-color 属性 为 边框 指定 颜色 。 其 一 般 格式 为 : 


border - color: border - top - color border - right ~ color border - bottom - color border - left ~ color 


可 以 使 用 其 中 任何 一 个 属性 只 设置 相应 边 的 颜色 ,不 会 直接 影响 其 他 边 的 颜色 。 

3. 设置 方 框 的 内 边 距 

设置 方 框 的 内 边 距 采用 padding 属性 ,其 用 法 与 margin 相似 。 

在 CSS 中 ,width 和 height 指 的 是 内 容 区 域 的 宽度 和 高 度 , 增 加 内 边 距 、 边 框 和 外 边 距 不 
会 影响 内 容 区 域 的 尺寸 ,但 是 会 增加 元 素 框 的 总 尺寸 。 

【 例 3.13】 在 ch3 网 站 中 添加 一 个 WebForm13. html 网 页 ,说 明 CSS 方 框 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch3 网 站 ,选择 “网 站 | 添加 新 项 命令, 出现“ 添加 新 项 -ch3” 对 话 框 , 在 中 间 列 表 中 
选择 “HTML 页 ”, 将 文件 名 称 改 为 WebForm13. html, 单 击 “ 添 加 ”按钮 。 

@ 进入 源 视图 ,设计 其 HTML 代码 如 下 : 


<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head> 
<meta http - equiv= "Content — Type" content = "text/html; charset = utf— 8"/> 
<title > 第 3 章 例 3.13 </title> 
< style type = "text/css"> 
div 
{ margin: 40px; border: 20px groove #630; 
padding: 60px; background - color: white; 
float: left; 
} 
</style> 
</head> 
<body> 
<div> 
< img src = "Images\imgl1. bmp" style= "width:150px" /> 
</div> 
</body> 
</html > 


该 网 页 在 IE 浏览 器 中 的 显示 结果 如 图 3. 28 所 示 , 图 中 标识 了 方 框 的 各 个 属性 的 含义 。 


78 
SP.NET 4. 5 动态 网 站 设计 教程 一 一 基于 C# 5.0 十 SQL Server 2012 


met p- oy 
La 本 


| -border20px 


图 3. 28 WebForml3. html 网 页 的 显示 结 


3.2.5 网 页 页 面 布 局 


在 网 页 设计 中 ,页 面 的 整体 结构 布局 是 十 分 重要 的 ,通常 采用 表格 或 方 框 布局 。 


利用 表格 布局 主要 通过 将 网 页 中 的 内 容 分 为 若干 个 区 块 , 用 表格 的 单元 格 代表 区 块 , 然 后 


分 别 在 不 同 的 区 块 内 填充 内 容 , 图 3. 29 所 示 的 是 一 种 基本 的 表格 布局 形式 。 


标题 栏 


图 3.29 一 种 基本 的 表格 布局 形式 


方 框 布局 就 是 采用 DIV 十 CSS 进行 页 面 布 
局 , 它 是 Web 2.0 时 代 提 倡 的 一 种 页 面 布 局 方式 ， 
是 一 种 比较 灵活 方便 的 布局 方法 。 对 于 DIV 十 
CSS 布局 的 页 面 , 浏 览 器 会 边 解 析 边 显示 。DIV 十 
CSS 网 页 布局 的 基本 流程 如 下 : 

Q@ 规划 网 页 结构 ,把 网 站 从 整体 上 分 为 几 个 
区 块 ,规划 好 每 个 区 块 的 大 小 和 位 置 。 


@ 将 区 块 用 二 div 二 标记 代替 ,设置 好 每 个 div 二 的 大 小 和 样式 。 
@ 通过 布局 属性 设置 二 div 二 的 位 置 布 局 。 
【 例 3.14】 在 ch3 网 站 中 添加 一 个 WebForm14. html 网 页 ,说 明 DIV 十 CSS 布局 方法 。 


解 : 其 步骤 如 下 。 


QO@ 打开 ch3 网 站 ,选择 “网 站 | 添加 新 项 命令, 出现“ 添加 新 项 -ch3” 对 话 框 ,在 中 间 列 表 中 
选择 "HTML 页 ”, 将 文件 名 称 改 为 WebForm14. html, 单 击 “ 添 加 ”按钮 。 
@ 进入 源 视 图 ,设计 其 HTML 代码 如 下 : 


<!DOCTYPE html > 


<html xmlns = "http://www.w3.org/1999/xhtml"> 


<head> 


<meta http - equiv = "Content — Type" content = "text/html; charset = utf— 8"/> 


<title > 第 3 章 例 3.14</title> 
<style type= "text/css"> 
x* {margin:0px; padding:0px;} 
body 


{ font ~ size: 12px; margin: 0px auto; 


height: auto; width: 440px; 

} 

.mainBox 

{ border: lpx dashed #0099CC; 
margin: 3px; padding: Opx; 
float: left; height: 200px; 
width: 100px; 
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} 
.mainBox h3 
{ float: left; height: 20px; 
width: 100px; color: ##FFFFFF; 
padding: 6px 3px 3px 10px; 
background - color: 井 0099CC; 
font - size: 16px; 
} 
.mainBox p 
{ line- height: 1.5em; 
text - indent: 2em; 
margin: 35px 5px 5px 5px; 
} 
</style> 
</head> 
<body> 
< h2 > ASP .NET 程序 设计 </h2 > 
<div class = "mainBox"> 
<h3 > 前 言 </h3 > 
<p> 正 文 内 容 </p> 
</div> 
<div class = "mainBox"> 
<h3 > 第 1 章 </h3 > 
<p> 正 文 内 容 </p> 
</div> 
<div class = "mainBox"> 
<h3> 第 3 章 </h3> 
<p> 正 文 内 容 </p> 
</div> 
<div class = "mainBox"> 
<h3> 第 3 章 </h3> 
<p> 正 文 内 容 </p> 
</div> 
<footer> 
<br /> 
< h3 > 结束 语 </h3 > 
</footer> 
</body> 
</html > 


该 网 页 在 下 浏览 器 中 的 显示 结果 如 图 3. 30 所 示 。 本 例 采用 内 联 样式 方式 设置 方 框 选 择 
器 和 类 选择 器 等 ,在 二 body 二 中 用 过 div 之 等 标记 进行 页 面 布 局 。 


~ ey 
总 备 3 音 例 3.14 x 
ASP.NET 程 序 设计 
| 

正文 内 容 正文 内 罕 。 || 正文 内 容 正文 内 容 | 
| | 
| | | | 
| | | 
| | 
| | 

| | | 
Ls 长 上 J 


图 3.30 WebForml4. html 网 页 的 显示 结果 
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练习 题 3 


. 简 述 HTML 文档 结构 。 

. 简 述 HTML 与 XHTML 的 异同 。 

. 简 述 HTML 常用 的 格式 标记 及 其 作用 。 

. 简 述 HTML 常用 的 列表 标记 及 其 作用 。 

. 简 述 HTML 常用 的 样式 / 节 标 记 及 其 作用 。 
. 简 述 HTML 常用 的 超 链接 标记 及 其 作用 。 
. 简 述 二 img 二 图 像 标 记 及 其 作用 。 

. 简 述 iframe 框架 标记 及 其 作用 。 

. 简 述 在 网 页 中 创建 表格 的 过 程 。 

10. 简 述 在 网 页 中 建立 表单 的 过 程 。 

11. 简 述 CSS 的 作用 。 

12. 简 述 使 用 样式 生成 器 设计 样式 表 文 件 的 过 程 , 并 说 明 如 何在 网 页 中 使 用 样式 表 文 件 。 
13. 简 述 CSS 方 框 模型 。 


上 机 实验 题 3 


在 ch3 网 站 中 设计 一 个 名 称 为 Experment3. html 的 网 页 ,用 于 输入 学 号 和 姓名 ,网 页 中 
有 一 个 5X2 的 表格 (该 表格 在 浏览 器 中 居中 显示 ) ,包含 3 个 HTML 文字 、3 个 文本 框 和 两 个 
按钮 ,它们 都 是 客户 端 控件 ,其 运行 界面 如 图 3. 31 所 示 。 其 中 采用 外 部 样式 表 文 件 设置 各 
HTML 标记 的 外 观 ,样式 表 文 件 为 StyleSheet2. css。 


Co 人 wo 


图 3.31 上 机 实验 题 3 网 页 的 运行 界面 


C 间 语言 基础 第 4 章 


C# 语 言 是 Microsoft 公司 推出 的 面向 对 象 的 编程 语言 ,是 专门 为 .NET 
Framework 量 身 打造 的 。 程 序 员 可 以 采用 C# 快速 ,方便 地 编写 各 种 基于 
.NET Framework 的 应 用 程序 。C# 作 为 ASP.NET 网 页 编程 的 脚本 语言 ,网 
页 运行 时 由 ASP.NET 引擎 执行 其 脚本 ,在 产生 最 终 的 HTML 网 页 后 由 服务 
器 发 送 给 客户 端 。 实 际 上 ,ASP.NET 4. 5 本 身 就 是 采用 C# 语 言 开发 的 ,所 以 
C# 不 仅 适用 于 Web 应 用 程序 的 开发 ,也 适用 于 开发 强大 的 系统 程序 。 总 之 ， 
C# 有 具有 简洁 的 语法 、 精 心 的 面向 对 象 设计 、 与 Web 的 紧密 结合 、 完 整 的 安全 性 
与 错误 处 理 等 特点 。 本 章 简要 介绍 C# 语 言及 其 在 Web 应 用 程序 开发 中 的 基 
本 内 容 。 

本 章 学 习 要 点 : 

回 掌握 C# 中 的 各 种 数据 类 型 。 

加 掌握 C# 中 值 类 型 和 引用 类 型 变量 的 定义 方法 及 其 区 别 。 

回 掌握 CH 中 类 的 声明 方法 。 

回 掌 握 C# 中 对 象 的 定义 和 使 用 方法 。 

加 掌握 C# 中 继承 的 使 用 方法 。 


4.1 C# 中 的 数据 类 型 


数据 类 型 是 用 来 区 分 不 同类 型 的 数据 ; 由 于 数据 在 存储 时 所 需要 的 容量 不 
同 , 不 同 的 数据 就 必须 要 分 配 不 同 大 小 的 内 存 空间 来 存储 ,所 以 将 数据 划分 成 
不 同 的 数据 类 型 。C# 中 数据 类 型 的 分 类 如 图 4. 1 所 示 , 从 中 可 以 看 到 ,C# 数 
据 类 型 主要 分 为 值 类 型 和 引用 类 型 两 大 类 。 
4.1.1 值 类 型 

值 类 型 的 变量 内 含 变 量 值 本 身 ,C# 的 值 类 型 可 以 分 为 简单 类 型 结构 体 类 

1. 整数 类 型 

整数 类 型 变量 的 值 为 整数 。 数 学 上 的 整数 可 以 从 负 无 穷 大 到 正 无 穷 大 ,但 
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是 由 于 计算 机 的 存储 单元 是 有 限 的 ,所 以 计算 机 语言 提供 的 整数 类 型 的 值 总 是 在 一 定 的 范围 
之 内 。 具 体 的 各 整数 类 型 及 其 取 值 范围 如 表 4.1 所 示 。 


sbyte byte 
short ushort 
整数 类 型 4 . _ 
int uint 
long ulong 
简单 类 型 4 字符 类 型 char 
布尔 类 型 bool 
float 


值 类 型 实数 类 型 4 double 


decimal 


结构 体 类 型 struct 
枚 举 类 型 enum 
引用 类 型 ee 人 
| 接口 interface 


数据 类 型 


图 4.1 C# 中 数据 类 型 的 分 类 
表 4.1 整数 类 型 及 其 取 值 范围 


类 型 标识 符 说 明 占用 位 数 取 值 范围 示 例 
sbyte 带 符号 字 节 型 8 一 128 一 127 sbyte i=10; 
byte 无 符号 字 节 型 8 0~255 byte i=10; 
short 带 符号 短 整 型 16 一 32 768~32 767 short i=10; 
ushort 无 符号 短 整 型 16 0 一 65 535 ushort i=10; 
int 带 符号 整 型 32 一 2 147 483 648 一 2 147 483 647 int i=10; 
uint 无 符号 整 型 32 0~4 294 967 295 uint i=10; 

uint i=10U; 
long 带 符号 长 整 型 64 一 9 223 372 036 854 775 808~ long i=10; 

9 223 372 036 854 775 807 long i=10L.; 

ulong 无 符号 长 整 型 64 0~18 446 744 073 709 551 615 ulong i=16; 

ulong i=16U; 

ulong i 一 16L; 

ulong i=16UL; 

2. 实数 类 型 


C# 中 的 实数 类 型 包括 单 精度 浮 点 数 (float) 、 双 精度 浮 点 数 (double) 和 固定 精度 的 浮 点 数 
(decimal) ,它们 的 差别 主要 在 于 取 值 范围 和 精度 不 同 。 各 实数 类 型 及 其 取 值 范围 与 精度 如 
表 4.2 所 示 。 

3. 字符 类 型 

在 C# 中 字符 类 型 采用 国际 上 公认 的 16 位 Unicode 字符 集 表示 形式 ,用 它 可 以 表示 世界 
上 的 多 种 语言 。 其 取 值 范围 为 \u0000' ~ uFFFF', 即 0~65 535。 字 符 类 型 的 标识 符 是 char， 


表 4.2 实数 类 型 及 其 取 值 范围 与 精度 


类 型 标识 符 说 明 取 值 范围 示 例 
float 单 精度 浮 点 数 土 1.5X10 必 一 3.4X10”, 精 度 为 7 位 数 float { 一 1. 23; 
double 双 精 度 浮 点 数 十 5.0X10 一 1.7X10% ,精度 为 15 一 16 位 数 ”double d==1.23; 
decimal 固定 精度 的 浮 点 数 ”1.0X10-2 一 7.9X1028 之 间 , 精 度 为 28 一 29 位 decimal d= 二 1.23; 

有 效 数 字 


因此 也 可 称 为 char 类 型 。 例 如 ,可 以 采用 以 下 方式 为 字符 变量 赋值 ; 


char c= 'H'; // 字 符 H 

char c= "\x0048'; // 字 符 十 六 进 制 转 义 符 (前 缀 为 \x) 

char c= '\u0048'; // 字 符 HUnicode 表示 形式 (前 缀 为 \u) 

char c= \r'; // 回 车 , 转 义 字符 (用 于 在 程序 中 指 代 特殊 的 控制 字符 ) 

在 表示 一 个 字符 常数 时 , 单 引 号 内 的 有 效 字符 数量 必须 且 只 能 是 一 个 ,并 且 不 能 是 单 引 号 
或 者 反 斜 杜 (\)。 

4. 布尔 类 型 


布尔 类 型 数据 用 于 表示 逮 辑 真 和 逻辑 假 , 布 尔 类 型 的 类 型 标识 符 是 bool。 

布尔 类 型 常数 只 有 两 种 值 , 即 true( 代 表 “ 真 ”) 和 false( 代 表 “ 假 ”)。 布 尔 类 型 数据 主要 应 
用 在 流程 控制 中 ,往往 通过 读 取 或 设 定 布 尔 类 型 数据 的 方式 来 控制 程序 的 执行 方向 。 

注意 : 在 C# 语 言 中 ,bool 类 型 不 能 像 C/C++ 语言 那样 可 能 直接 转换 为 int 类 型 ,例如 ， 
“int a 二 (2 过 3);” 在 C/C++ 中 都 是 正确 的 ,但 在 C# 中 不 允许 这 样 ,会 出 现 “ 无 法 将 类 型 bool 
隐 式 转换 为 int” 的 编译 错误 。 


4.1.2 引用 类 型 


C# 中 的 另 一 大 数据 类 型 是 引用 类 型 ,引用 类 型 也 称 为 参考 类 型 。 和 值 类 型 相 比 ,引用 类 
型 的 变量 不 直接 存储 所 包含 的 值 , 而 是 指向 它 所 要 存储 的 值 。 换 句 话 说 , 值 类 型 变量 的 内 存 空 
间 中 存储 的 是 实际 数据 ,而 引用 类 型 变量 在 其 内 存 空间 中 存储 的 是 一 个 指针 ,该 指针 指向 存储 
数据 的 另 一 块 内 存 位 置 。 由 此 可 见 , 值 类 型 变量 的 内 存 开销 小 ,访问 速度 快 ,而 引用 类 型 变量 
的 内 存 开销 大 ,访问 速度 稍 慢 。 

引用 类 型 共 分 4 种 类 型 , 即 类 接口 .数组 和 委托 等 。 

1. object 类 

object 是 C# 中 所 有 类 型 (包括 所 有 的 值 类 型 和 引用 类 型 ) 的 基 类 ,C# 中 的 所 有 类 型 都 直 
接 或 间接 地 从 object 类 中 继承 。 因 此 ,对 一 个 object 的 变量 可 以 赋予 任何 类 型 的 值 : 


float f= 1.23; 


object obj1; // 定 义 objl 对 象 
objl = fi; 
object obj2 = "China" // 定 义 obj2 对 象 并 赋 初 值 


对 object 类 型 的 变量 声明 采用 object 关键 字 , 这 个 关键 字 是 在 . NET Framework 的 命名 
空间 System 中 定义 的 ,是 类 System. Object 的 别名 。 

2. string 类 

C# 中 还 定义 了 一 个 string 类 ,表示 一 个 Unicode 字符 序列 ,专门 用 于 对 字符 串 的 操作 。 
同样 ,这 个 类 也 是 在 .NET Framework 的 命名 空间 System 中 定义 的 ,是 类 System. String 的 
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别名 。 
字符 串 在 实际 中 的 应 用 非常 广泛 ,利用 string 类 中 封装 的 各 种 内 部 操作 可 以 很 容易 地 完 
成 对 字符 串 的 处 理 。 例 如 : 


string strl = "123" + "abc"; //" + "运算 符 用 于 连接 字符 串 

char c= "Hello World! "[1]; //"[]" 运 算 符 可 以 访问 string 中 的 单个 字符 ,c= 'e' 
string str2 = "China"; 

string str3 = @"China"; // 用 @ 表 示 后 跟 一 个 严格 字符 串 , 其 中 \n 等 不 再 作为 转 义 符 
bool b= (str2 == str3); //" == "运算 符 用 于 两 个 字符 串 比 较 ,b= true 


4.2 C# 中 的 变量 和 常量 


在 程序 的 执行 过 程 中 其 值 不 发 生 改变 的 量 称 为 常量 ,其 值 可 变 的 量 称 为 变量 。 它 们 可 与 
数据 类 型 结合 起 来 分 类 。 在 程序 中 ,常量 是 可 以 不 经 说 明 而 直接 引用 的 ,变量 则 必须 先 定义 后 
使 用 。 


4.2.1 变量 


变量 是 在 程序 的 运行 过 程 中 其 值 可 以 发 生变 化 的 量 , 可 以 在 程序 中 使 用 变量 来 存储 各 种 
各 样 的 数据 ,并 对 它们 进行 读 、 写 .运算 等 操作 。 

1. 变量 的 定义 

在 C# 程 序 中 使 用 某 个 变量 之 前 ,必须 要 告诉 编译 器 它 是 一 个 什么 样 的 变量 ,通过 对 变量 
定义 来 完成 。 定 义 变量 的 方法 如 下 : 

[访问 修饰 符 ] 数 据 类 型 ”变量 名 [ = 初始 值 ]; 

例如 ， 

string name= " 王 华 "; 

int age= 20; 

也 可 以 同时 声明 一 个 或 多 个 给 定 类 型 的 变量 ,例如 : 

int a=1,b=2,c=3; 


变量 具有 作用 范围 ,C# 是 纯 面 向 对 象 的 语言 ,没有 像 C/C++ 中 那样 的 全 局 变量 ,只 能 在 
类 中 定义 变量 ,包括 类 字段 和 类 函数 成 员 中 定义 的 变量 ,前 者 的 作用 范围 是 整个 类 ,后 者 的 作 
用 范围 是 该 变量 所 在 的 函数 成 员 。 

2. 理解 值 类 型 的 变量 

在 定义 变量 时 ,如 果 指 定 变 量 的 类 型 是 值 类 型 ,那么 这 个 变量 就 是 值 类 型 的 变量 (或 值 变 
量 )。 值 变量 直接 把 值 存放 在 这 个 变量 名 标记 的 存储 位 置 上 , 值 类 型 的 变量 是 在 栈 空 间 中 分 
配 的 。 

当 定义 一 个 值 类 型 变量 并 且 给 它 赋值 的 时 候 , 这 个 变量 只 能 存储 相同 类 型 的 数据 。 所 以 ， 
一 个 int 类 型 的 变量 只 能 存放 int 类 型 的 数据 。 另 外 , 当 把 值 赋 给 某 个 值 类 型 的 变量 时 ,C# 首 
先 创 建 这 个 值 的 一 个 副本 ,然后 把 这 个 副本 放 在 变量 名 所 标记 的 存储 位 置 上 。 例 如 : 

int x; 

int y= 2; 

x=y; 


在 这 段 代码 中 , 当 把 变量 y 的 值 赋 给 时 ,程序 会 创建 变量 y 的 值 的 副本 , 即 2, 然 后 把 这 
个 值 放 到 z 中 ,如 图 4.2 所 示 。 如 果 后 面 的 程序 修改 了 > 的 值 ,就 不 会 影响 x 的 值 。 这 看 起 
来 是 很 显然 的 ,但 对 于 引用 类 型 的 变量 来 说 就 不 是 这 样 的 了 。 

3. 理解 引用 类 型 的 变量 

在 定义 变量 时 ,如 果 指 定 变 量 的 类 型 是 引用 类 型 ,那么 这 个 变量 就 是 引用 类 型 的 变量 (或 
引用 变量 )。 引 用 表示 所 使 用 的 是 变量 或 对 象 的 地 址 而 不 是 变量 或 对 象 本 身 。 当 定义 引用 变 
量 时 ,程序 只 是 分 配 了 存放 这 个 引用 的 存储 空间 , 它 是 在 栈 空间 中 分 配 的 。 另 外 还 要 创建 对 象 
实例 并 把 该 实例 的 存储 地 址 赋 给 该 引用 变量 ,需要 使 用 new 操作 符 。 例 如 

MyClass pl; //MyClass 是 已 声明 的 类 或 类 型 

pl = new MyClass(); 

MyClass p2 = pl; 

第 1 个 语句 定义 了 MyClass 类 的 一 个 引用 类 型 变量 pl。 第 2 个 语句 使 用 new 操作 符 来 
创建 MyClass 类 实例 ,C# 会 在 堆 存 储 空间 中 分 配 该 实例 ,然后 把 这 个 实例 的 地 址 赋 给 这 个 引 
用 变量 pl, 这 个 引用 变量 就 可 以 用 来 引用 堆 中 创建 的 那个 实例 了 。 第 3 个 语句 定义 了 
MyClass 类 的 一 个 引用 类 型 变量 p2, 并 让 它 指向 pl 所 指 的 MyClass 实例 。p1 和 p2 引用 变量 
的 空间 分 配 如 图 4. 3 所 示 。 通 常 将 pl 和 它 所 指 的 MyClass 实例 称 为 pl 对 象 。 


MyClass 类 实例 
x pl 一 一 
? 2 | 
栈 空间 栈 空间 堆 空间 
图 4.2 值 变量 的 空间 分 配 图 4.3 引用 类 型 变量 的 空间 分 配 


由 于 实例 是 在 堆 存 储 空 间 中 分 配 的 ,在 程序 执行 时 ,.NET Framework 会 跟踪 堆 存 储 空 
间 ,一 旦 某 个 指向 实例 的 引用 变量 超出 了 作用 范围 ,就 自动 释放 该 实例 ,不 需要 程序 员 编写 专 
门 的 代码 释放 实例 空间 ,从 而 达到 垃圾 自动 回收 的 目的 ,这 是 C# 的 优点 之 一 。 


4.2.2 常量 


所 谓 常量 ,就 是 在 程序 执行 中 其 值 保 持 固 定 不 变 的 量 。 常 量 一 般 分 为 直接 常量 和 符号 常 
量 , 常 量 的 类 型 可 以 是 任何 一 种 值 类 型 或 引用 类 型 。 

1. 直接 常量 

直接 常量 是 指 把 程序 中 不 变 的 量 直接 硬 编 码 为 数值 或 字符 串 值 。 例 如 ,以 下 都 是 直接 
常量 ， 


100 // 整 型 直接 常量 
1.23e5 // 浮 点 型 直接 常量 
true // 布 尔 型 直接 常量 
"中 华人 民 共 和 国 " // 字 符 串 型 常量 


null // 对 象 引用 常量 
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在 程序 中 书写 一 个 十 进 制 的 数值 常数 时 ,C# 默认 按照 以 下 方法 判断 一 个 数值 常数 属于 
哪 种 C# 数值 类 型 : 
。 如 果 一 个 数值 常数 不 带 小 数 点 ,如 12345, 则 这 个 常 的 类 型 是 整 型 。 
。 对 于 一 个 属于 整 型 的 数值 常数 ,C# 按 以 下 顺序 判断 该 数 的 类 型 : int、uint、 long、 
ulong。 
。 如 果 一 个 数值 常数 带 小 数 点 ,如 3. 14, 则 该 常数 的 类 型 是 浮 点 型 中 的 double 类 型 。 
2. 符号 常量 
符号 常量 是 通过 关键 字 const 声明 的 常量 ,包括 常量 的 名 称 和 它 的 值 。 常 量 的 声明 格式 
如 下 : 
const 数据 类 型 ”常量 名 = 初始 值 ; 
其 中 ,“ 常 量 名 ”必须 是 C# 的 合法 标识 符 , 在 程序 中 通过 常量 名 访问 该 常量 。“ 类 型 标识 
符 ? 指 示 了 所 定义 的 常量 的 数据 类 型 ,而 “初始 值 ? 计 算 结 果 是 所 定义 的 常量 的 值 。 
符号 常量 具有 以 下 特点 : 
。 在 程序 中 ,常量 只 能 被 赋予 初始 值 。 一 旦 赋予 一 个 常量 初始 值 ,这 个 常量 的 值 在 程序 
的 运行 过 程 中 就 不 允许 改变 , 即 无 法 对 一 个 常量 赋值 。 
。 在 定义 常量 时 ,表达 式 中 的 运算 符 对 象 只 允许 出 现 常 量 和 常数 ,不 能 有 变量 存在 。 
例如 ,以 下 语句 定义 了 一 个 double 型 的 常量 PI, 它 的 值 是 3. 141 592 65 : 


const double PI = 3.14159265; 


4.3 C# 中 的 运算 符 


C# 中 的 表达 式 由 运算 数 和 运算 符 组 成 ,运算 符 是 用 来 定义 类 实例 中 表达 式 运算 数 的 
运算 。 
4.3.1 常用 的 C# 运 算 符 
依照 运算 符 作用 的 运算 数 的 个 数 来 分 ,C# 中 共有 下 面 3 种 类 型 的 运算 符 。 
。 一 元 运算 符 , 一 元 运算 符 带 一 个 运算 数 并 使 用 前 级 符 (如 一 zx) 或 后 缀 符 (如 zx 十 十 )。 
。 二 元 运算 符 : 二 元 运算 符 带 两 个 运算 数 并 且 全 部 使 用 中 缓 符 (如 xz 十 y) 。 
。 三 元 运算 符 : 只 存在 唯一 一 个 三 元 运算 符 "?:"。 三 元 运算 符 带 3 个 运算 数 并 使 用 中 级 


符 (c? z:y)。 
下 面 分 别 给 出 使 用 运算 符 的 例子 : 
int x = 3; 
int y= 6; 
int z; 
XH+ 7 // 一 元 运算 符 
一 一 3 // 一 元 运算 符 
z=x+y; // 二 元 运算 符 
Y= (x<10?0:1); // 三 元 运算 符 


注意 : 最 后 一 行 代码 表示 当 x 过 10 成 立 的 时 候 y 取 值 为 0, 否 则 取 值 为 ]。 
表 4.3 列 出 了 C# 支 持 的 运算 符 。 


表 4.3 C# 中 的 运算 符 
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运算 符 类 别 运 算 符 
算术 +,—、*,/ 
人 逻辑 B&B 
字符 串 串 连 二 
递增 .递减 本 中 5 一 
移 位 < 
关系 三 l= <> 三 
赋值 一 十 一 、 一 一 、* 一 /一 、% 一 | 一 一、 二 < 一 、>>> 一 
成 员 访问 
索引 口 
条 件 ?: 
委托 串 连 和 删除 二 = 一 = 
创建 对 象 new 
类 型 信息 is \as \sizeof .typeof 
溢出 异常 控制 checked unchecked 


4.3.2 运算 符 的 优先 级 


当 一 个 表达 式 包含 多 个 运算 符 时 ,运算 符 的 优先 级 控制 着 单个 运算 符 求 值 的 顺序 ,一 般 先 
执行 优先 级 高 的 运算 符 , 同 级 的 运算 符 按 照 从 左 到 右 的 顺序 执行 ,括号 的 优先 级 最 高 。 例 如 对 


于 表达 式 : 


XxX+yx*z 


首先 求 出 y* <, 然 后 将 结果 与 x 相 加 ,因为 * 的 优先 


级 比 十 的 优先 级 要 高 。 如 果 需 要 调 


整 优先 级 ,可 以 使 用 括号 "()”。 例 如 需要 先 求 x 与 y 的 和 ,然后 再 将 结果 与 x 相 乘 , 则 可 以 编 


写 如 下 表达 式 : 


(x+y)x*z 


还 要 考虑 运算 符 的 结合 性 ,函数 是 左 结 合 的 ,其 优先 级 高 。 例 如 ,对 于 表达 式 : 


2#03+5)=£(7) 


首先 计算 A(7) 的 值 ,接着 计算 (3 十 5) ,再 计算 2* (3 十 5) ,最 后 做 减法 运算 。 


表 4.4 总 结 了 常见 运算 符 从 高 到 低 的 优先 级 顺序 ,每 
表 4.4 常见 运算 符 的 优先 


个 组 中 的 运算 符 具有 相同 的 优先 级 。 
级 


运算 符 类 别 运 算 符 运算 符 类 别 运 算 符 
基本 2 一 一 、 逻辑 与” Zz&y 
new、 typeof、 sizeof、checked、 人 逻辑" 异 或 ” 工 ^y 
unchecked 一 过 人 逻辑 “或 工 | y 
一 元 Fey 一 条 件 “与 ” zx& Ey 
(Dz 条 件 “ 或 ” zly 
乘法 工 关 ZL/Y、 工 9%y 条 件 运 算 ?: 
加 法 I+yx—y 赋值 X=y,T 二 二 y ,XT 一 二 yx* 二 y、 
移 位 Xx<<yr>>y Z/ 一 y\% 一 yz 人 一 yz 一 人 、 
关系 By Ey 
相等 = 一 


88 
SP.NET 4. 5 动态 网 站 设计 教程 一 一 基于 C# $.0 十 SQL Server 2012 


4.3.3 装 箱 和 拆 箱 


装 箱 和 拆 箱 是 C# 类 型 系统 中 重要 的 概念 。 通 过 装 箱 和 拆 箱 实现 值 类 型 和 引用 类 型 数据 
的 相互 转换 ,也 就 是 说 , 装 箱 和 拆 箱 是 实现 值 类 型 和 引用 类 型 相互 转换 的 “桥梁 ”。 

1. 装 箱 转 换 

装 箱 转换 是 指 将 一 个 值 类 型 的 数据 隐 式 地 转换 成 一 个 引用 类 型 的 数据 。 把 一 个 值 类 型 装 
箱 就 是 创建 一 个 object 类 型 的 实例 ,并 把 该 值 类 型 的 值 复制 给 这 个 object 实例 。 

例如 ,下 面 的 语句 就 执行 了 装 箱 转换 : 

int i= 10; 

object obj = i; // 装 箱 

2. 拆 箱 转 换 

拆 箱 转换 是 指 将 一 个 引用 类 型 的 数据 显 式 地 转换 成 一 个 值 类 型 数据 。 

拆 箱 操作 分 为 两 步 : 首先 检查 对 象 实例 ,确保 它 是 给 定 值 类 型 的 一 个 装 箱 值 ,然后 把 实例 
的 值 复制 到 值 类 型 数据 中 。 例 如 ,下 面 的 语句 就 执行 了 拆 箱 转换 : 

object obj = 10; 

int i= (int)obj; // 拆 箱 

拆 箱 转换 需要 (而 且 必 须 ) 执 行 显 式 转换 ,这 是 它 与 装 箱 转换 的 不 同 之 处 。 


4.4 结构 体 类 型 和 枚 举 类 型 


4.4.1 结构 体 类 型 


结构 体 类 型 是 一 种 值 类 型 ,对 应 变量 的 值 保存 在 栈 内 存 区 域 。 
1. 结构 体 类 型 的 声明 
结构 体 类 型 由 若干 “成员 ”组 成 。 数 据 成 员 称 为 字段 ,每 个 字段 都 有 自己 的 数据 类 型 。 声 
明 结 构 体 类 型 的 一 般 格式 如 下 : 
struct 结构 体 类 型 名 称 
{ [字段 访问 修饰 符 ] 数据 类 型 字段 1; 
[字段 访问 修饰 符 ] 数据 类 型 字段 2; 


[字段 访问 修饰 符 ] 数据 类 型 字段 n; 


}; 

其 中 ,struct 是 结构 体 类 型 的 关键 字 。 “字段 访问 修饰 符 ” 的 主要 取 值 有 public 和 private 
(默认 值 ) ,public 表示 可 以 通过 该 类 型 的 变量 访问 该 字段 ,private 表示 不 能 通过 该 类 型 的 变 
量 访问 该 字段 。 

例如 ,以 下 声明 一 个 具有 姓名 和 年 龄 的 结构 体 类 型 Student: 


struct Student // 声 明 结 构 体 类 型 Student 
{ public int xh; // 学 号 
public string xm; // 姓 名 


public string xb; // 性 别 


public int nl; // 年 龄 
public string bh; // 班 号 
} 
在 上 述 结构 体 类 型 声明 中 ,结构 体 类 型 名 称 为 Student。 该 结构 体 类 型 由 5 个 成 员 组 成 ， 
第 1 个 成 员 是 xh ,为 整 型 变量 ; 第 2 个 成 员 是 xm, 为 字符 串 类 型 ; 第 3 个 成 员 是 xb, 为 字符 串 
类 型 ; 第 4 个 成 员 是 nl ,为 整 型 变量 ; 第 5 个 成 员 是 bh ,为 字符 串 类 型 。 
2. 结构 体 类 型 变量 的 定义 
在 声明 一 个 结构 体 类 型 后 ,可 以 定义 该 结构 体 类 型 的 变量 (简称 为 结构 体 变量 )。 定 义 结 
构 体 变量 的 一 般 格式 如 下 : 
结构 体 类 型 ”结构 体 变 量 ; 
例如 ,在 声明 结构 体 类 型 Student 后 ,定义 它 的 两 个 变量 如 下 ; 


Student sl1, s2; 


3. 结构 体 变量 的 使 用 

结构 体 变 量 的 使 用 主要 包括 字段 访问 和 赋值 等 ,这 些 都 是 通过 结构 体 变量 的 字段 实 
现 的 。 

(1) 访问 结构 体 变量 字段 

访问 结构 体 变量 字段 的 一 般 格式 如 下 : 

结构 体 变量 名 . 字段 名 

例如 ,sl. xh 表示 结构 体 变量 sl 的 学 号 ,s2. xm 表示 结构 体 变量 s2 的 姓名 。 

(2) 结构 体 变量 的 赋值 

结构 体 变 量 的 赋值 有 下 面 两 种 方式 。 

。 结构 体 变量 的 字段 赋值 : 方法 与 普通 变量 相同 。 

。 结构 体 变量 之 间 赋 值 : 要 求 赋 值 的 两 个 结构 体 变 量 必须 类 型 相同 。 例 如 ， 

sl = s2; 


这 样 s2 的 所 有 字段 值 赋 给 sl 的 对 应 字段 。 
4.4.2 枚 举 类 型 


枚 举 类 型 也 是 一 种 自 定义 数据 类 型 , 它 允 许 用 符号 代表 数据 。 枚 举 是 指 程序 中 某 个 变量 
具有 一 组 确定 的 值 ,通过 “ 枚 举 ” 可 以 将 其 值 一 一 列 出 来 。 这 样 ,使 用 枚 举 类 型 就 可 以 将 常用 颜 
色 用 符号 Red、Green、Blue、White、Black 表示 ,从 而 提高 了 程序 的 可 读 性 。 

1. 枚 举 类 型 的 声明 

枚 举 类 型 使 用 enum 关键 字 声 明 ,其 一 般 语法 形式 如 下 : 

enum 枚 举 名 { 枚 举 成 员 1, 枚 举 成 员 2,…} 

其 中 ,enum 是 枚 举 类 型 的 关键 字 。 例 如 ,以 下 声明 一 个 名 称 为 color 的 表示 颜色 的 枚 举 
类 型 ; 

enum Color {Red, Green, Blue, White, Black} 

在 声明 枚 举 类 型 后 ,可 以 通过 枚 举 名 来 访问 枚 举 成 员 , 其 使 用 语法 如 下 : 

枚 举 名 . 枚 举 成 员 
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2. 枚 举 成 员 的 赋值 

在 声明 的 枚 举 类 型 中 ,每 一 个 枚 举 成 员 都 有 一 个 相对 应 的 常量 值 .默认 情况 下 C# 规 定 第 
1 个 枚 举 成 员 的 值 取 0, 它 后 面 的 每 一 个 枚 举 成 员 的 值 按 加 上 1 递增 。 例 如 前 面 的 Color, Red 
值 为 0,Green 值 为 1,Blue 值 为 2, 依 此 类 推 。 

用 户 可 以 为 一 个 或 多 个 枚 举 成 员 赋 整 型 值 , 当 某 个 枚 举 成 员 赋值 后 ,如 果 其 后 的 枚 举 成 员 
没有 赋值 , 它 自 动 在 前 一 个 枚 举 成 员 值 之 上 加 1。 例 如 : 

enum Color { Red= 0，Green，Blue = 3，White，Black= 1}; 

则 这 些 枚 举 成 员 的 值 分 别 为 0、1、3、4、1。 

3. 枚 举 类 型 变量 的 定义 

在 声明 一 个 枚 举 类 型 后 ,可 以 定义 该 枚 举 类 型 的 变量 (简称 为 枚 举 变量 ) 。 定 义 枚 举 变量 
的 一 般 格式 如 下 : 

枚 举 类 型 ” 枚 举 变 量 ; 

例如 ,在 声明 枚 举 类 型 Color 后 ,定义 它 的 两 个 变量 如 下 : 

Color cl1,c2; 

4. 枚 举 变量 的 使 用 

枚 举 变量 的 使 用 包括 赋值 和 访问 等 。 

(1) 枚 举 变量 的 赋值 

为 枚 举 变 量 赋 值 的 语法 格式 如 下 : 

枚 举 变量 = 枚 举 名 . 枚 举 成 员 

例如 : 

cl = Color. Red; 

(2) 枚 举 变量 的 访问 

枚 举 变量 像 普通 变量 一 样 直 接 访问 。 


4.5 C# 中 的 控制 语句 
控制 语句 用 于 改变 程序 的 正常 流程 ,主要 有 选择 控制 语句 和 循环 控制 语句 。 


4.5.1 选择 控制 语句 


C# 中 的 选择 控制 语句 有 这 语 句 、if…else 语句 、if…else if 语句 和 switch 语句 ,它们 根据 
指定 条 件 的 真 假 值 确定 执行 哪些 简单 语句 ,其 中 简单 语句 既 可 以 是 单个 语句 ,也 可 以 是 用 *{})” 


括 起 来 的 复合 语句 。 
1. 放 语 句 
证 语句 用 于 在 程序 中 有 条 件 地 执行 某 一 语句 序列 ,其 基本 语法 格式 如 下 : 
二 (条 件 表达 式 ) 语 句 ; 


其 中 ,“ 条 件 表达 式 ” 是 一 个 关系 表达 式 或 逻辑 表达 式 , 当 “条 件 表达 式 ” 为 True 时 ,执行 
后 面 的 “语句 ”。 
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如 果 希 望 计 语句 在 “条件 表达 式 ? 为 True 和 False 时 分 别 执行 不 同 的 语句 , 则 用 else 引入 
条 件 表达 式 为 False 时 执行 的 语句 序列 ,这 就 是 if…else 语句 , 它 根 据 不 同 的 条 件 分 别 执行 不 
同 的 语句 序列 ,其 语法 形式 如 下 : 
证 (条 件 表达 式 ) 
语句 1; 
else 
语句 2; 
其 中 的 “条 件 表达 式 ” 是 一 个 关系 表达 式 或 逻辑 表达 式 。 当 “条 件 表 达 式 ”为 True 时 执行 
“语句 1"， 当 "条 件 表达 式 "为 False 时 执行 "语句 2”。 
3. if…else if 语句 
if…else if 语 名 用 于 进行 多 重 判断 , 其 语法 形式 如 下 : 
证 (条 件 表达 式 1) 语句 1; 
else 证 (条 件 表 达 式 2) 语句 2; 


else if (条 件 表达 式 n) 语句 

else 语句 n+1; 

首先 计算 “条 件 表达 式 1” 的 值 。 如 果 为 True, 则 执行 “语句 1”; 如 果 * 条 件 表达 式 1” 的 值 
为 False, 则 继续 计算 “条 件 表达 式 2” 的 值 。 如 果 为 True, 则 执行 “语句 2”; 如 果 * 条 件 表达 式 
2” 值 为 False, 则 继续 计算 “条 件 表达 式 3” 的 值 , 依 此 类 推 。 如 果 所 有 条 件 中 给 出 的 表达 式 值 
都 为 False, 则 执行 else 后 面 的 “语句 n 十 1”。 如 果 没 有 else, 则 什么 也 不 做 , 转 到 该 if*…else 让 
语句 后 面 的 语句 继续 执行 。 

【 例 4.1】 在 D 盘 ASP.NET 目录 中 建立 一 个 ch4 的 子 目录 ,将 其 作为 网 站 目录 ,并 创建 
一 个 WebForml 网 页 ,其 功能 是 将 用 户 输入 的 学 生 分 数 转 换 成 等 级 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012 。 

@ 选择 “文件 | 新 建 | 网 站 ”命令 ,出 现 “新 建 网 站 ”对 话 框 ,然后 选择 “ASP.NET 空 网 站 ” 
模板 ,选择 “Web 位 置 "为 "文件 系统 ”, 单 击 * 浏 览 "按钮 ,选择 *D:\ASP.NET\ch4? 目 录 , 单 击 
“确定 ?按钮 ,创建 一 个 空 的 网 站 ch4 。 

@ 选择 “网 站 | 添加 新 项 "命令 ,出 现 “ 添 加 新 项 -ch4” 对 话 框 ,在 中 间 列 表 中 选择 "Web 窗 
体 页 ” ,将 文件 名 称 改 为 WebForml. aspx, 其 他 保持 默认 项 (创建 代码 隐藏 页 模型 的 网 页 ) , 单 
击 “ 添 加 ”按钮 。 

@ 单 击 5 设计 选项 卡 进 入 网 页 的 设计 视图 ,从 标准 工具 箱 将 一 个 入 ”Label 控件 拖 放 到 第 
一 行 中 (默认 ID 为 Labell), 通 过 属性 窗口 将 其 Text 属性 改 为 “分 数 ”, 字 体 改 为 “楷体 ， 
Medium” 并 加 粗 , ForeColor 属性 改 为 Blue。 在 该 行 拖 放 一 个 国 TexBox 控件 (默认 ID 为 
TextBoxl), 所 有 属性 保持 默认 值 。 

@ 按 两 次 Enter 键 将 光标 移 到 第 3 行 , 拖 放 一 个 国 Button 控件 (默认 ID 为 Button1) , 通 
过 属性 窗口 将 其 Text 属性 改 为 “转换 ”, 字 体 改 为 黑体, Medium” 并 加 粗 ,ForeColor 属性 改 
为 Red。 

@ 再 按 两 次 Enter 键 将 光标 移 到 第 5 行 , 拖 放 一 个 入 ”Label 控件 (默认 ID 为 Label2) ,将 
其 Text 属性 改 为 “等 级 ”, 其 他 属性 与 Labell 相同 。 在 该 行 拖 放 一 个 国 TexBox 控件 (默认 ID 
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为 TextBox2) ,将 其 ReadOnly 属性 改 为 True, 其 他 属性 保持 默认 值 。 最 终 的 设计 界面 如 
4.4 所 示 。 

说 明 : 如 果 要 为 多 个 控件 设置 相同 的 属性 , 按 Ctrl 键 并 选中 这 些 控件 ,进入 属性 窗口 设置 
相应 的 属性 即 可 。 

@ 双击 Buttonl 控件 ,出 现代 码 编辑 窗口 ,输入 以 下 事件 过 程 代码 : 


protected void Button1_Click(object sender, EventArgs e) 
hl int n; 
if (TextBoxl. Text!= "") 
{ n = int.Parse(TextBoxl.Text); 
if (n>= 90) 
TextBox2. Text = "优秀 "; 
else if (n>= 80) 
TextBox2. Text = "优良 "; 
else if (n>= 70) 
TextBox2. Text = "中 等 "; 
else if (n>= 60) 
TextBox2. Text = "及 格 "; 
else 
TextBox2. Text = "不 及 格 "; 


} 

其 中 ,n 二 int. Parse(TextBoxl. Text) 语 句 表 示 将 TextBoxl 文本 框 中 用 户 输 入 的 值 ( 默 
认为 字符 串 ) 转 换 为 整数 后 赋 给 int 型 变量 ,然后 用 让 语 句 进行 判断 。 

@ 单 击 。 源 选项 卡 进 入 网 页 的 源 视 图 ,对 应 的 代码 如 下 : 


<% @ Page Language = "C 井 ”RutoEventWireup = "true" CodeFile = "WebForm1l.aspx.cs" 
Inherits = "WebForml" %> 
<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head runat = "server"> 
<meta http - equiv = "Content ~ Type" content = "text/html; charset = utf ~ 8"/> 
<title></title> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
<asp:Label ID = "Labell" runat = " server" Font - Bold= "True" Font- Names = "楷体 " 
Font - Size = "Medium" ForeColor = "Blue" Text = "分 数 "></asp:Label > 
<asp:TextBox ID = "TextBoxl" runat = "server" Width = "100px"></asp:TextBox> 
<br /><br /> 
<asp:Button ID = "Button1”runat = "server" Font ~ Bold= "True" 
Font - Names = "黑体 ”Font - Size = "Medium" ForeColor = "Red" 
OnClick = "Buttonl_Click"” Text = "转换 ”/> 
<br /><br /> 
<asp:Label ID = "Label2" runat = "server" Font - Bold= "True" Font- Names = "楷体 " 
Font - Size = "Medium" ForeColor = "Blue" Text = "等 级 "></asp:Label> 
<asp:TextBox ID = "TextBox2" runat = "server" Width= "94px" 
ReadOnly = "True"></asp:TextBox > 
</div> 


</form> 
</body> 
</html > 
从 中 看 到 ,Visual Studio 将 开发 人 员 的 设计 操作 自动 转换 为 网 页 的 界面 代码 ,从 而 方便 
进行 可 视 化 设计 。 


@ 单 击 工 具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,在 “分 数 "文本 框 中 输入 85 , 单 击 “ 转 
换 ” 按 钮 ,得 到 对 应 的 等 级 为 “优良 ”, 如 图 4.5 所 示 。 


|G rp/ecahortsss0 p- © 
古 localhost x 


设计 ] 日 折 分 | " 源 | |4][<asp:ButtonsB'|》 
图 4.4 WebForml 网 页 设计 界面 图 4.5 WebForml 网 页 运行 界面 


说 明 : 为 了 使 界面 更 加 美观 ,可 以 采用 第 3 章 介绍 的 HTML5 和 CSS3 进行 美化 设计 。 
4. switch 语句 
switch 语句 也 称 为 开关 语句 ,适合 有 多 重 选择 的 场合 ,用 于 测试 某 一 个 变量 具有 多 个 值 
时 所 执行 的 动作 。switch 语句 的 语法 形式 如 下 : 
switch (表达 式 ) 
{ case 常量 表达 式 1: 语句 1; 
case 常量 表达 式 2: 语句 2; 
case 常量 表达 式 a: 语句 n; 
default: 语 句 n+1; 
} 
switch 语句 控制 传递 给 与 “表达 式 ” 值 匹配 的 case 块 。switch 语句 可 以 包括 任意 数目 的 
case 块 ,但 是 任何 两 个 case 块 都 不 能 具有 相同 的 “常量 表达 式 ” 值 。 语 句 体 从 选 定 的 语句 开始 
执行 ,直到 break 语句 将 控制 传递 到 case 块 以 外 。 在 每 一 个 case 块 ( 包 括 default 块 ) 的 后 面 
都 必须 有 一 个 跳 转 语句 (如 break 语句 )。C# 不 支持 从 一 个 case 块 显 式 地 贯穿 到 另 一 个 case 
块 (这 一 点 与 Ct+ 中 的 switch 语句 不 同 )。 但 有 一 个 例外 , 当 case 语句 中 没有 代码 时 可 以 不 包 
含 break 语句 。 
如 果 没 有 任何 case 表达 式 与 开关 值 匹配 , 则 控制 传递 给 跟 在 可 选 default 标签 后 的 语句 ; 
如 果 没 有 default 标签 , 则 控制 传递 到 switch 语句 以 外 。 
例如 ,可 以 将 例 4. 1 的 Buttonl_Click 事件 过 程 等 价 地 改 为 : 
protected void Buttonl_Click(object sender, EventArgs e) 
{ int n; 
if (TextBox1. Text!= "") 
{ n= int.Parse(TextBoxl.Text); 


switch(n/10) // 整 除 
{ case 9: TextBox2. Text = "优秀 "; break; 
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case 8: TextBox2. Text = "优良 ";break; 
case 7: TextBox2. Text = "中 等 ";break; 
case 6: TextBox2. Text = "及 格 ";break; 
default: TextBox2. Text = "不 及 格 "; break; 


} 


4.5.2 循环 控制 语句 


C# 中 的 循环 控制 语句 有 while、do-while 和 for 语句 ,另外 ,break 和 continue 语句 用 于 结 
束 整 个 循环 和 结束 当前 一 趟 循环 。 

1. while 语句 

while 语句 的 一 般 语 法 格式 如 下 : 

while( 条 件 表达 式 ) 语 句 ; 

当 “ 条 件 表达 式 ” 的 运算 结果 为 True 时 , 则 重复 执行 “语句 ”。 每 执行 一 次 “语句 ”后 ,就 会 
重新 计算 一 次 “条 件 表 达 式 ”, 当 该 表达 式 的 值 为 False 时 ,while 循环 结束 。 

【 例 4.2】 在 ch4 网 站 中 设计 一 个 求 1~n 之 和 的 网 页 WebForm2, 其 中 为 正 整数 ,由 用 
户 输 入 。 

- 解 : 其 步骤 如 下 。 

] @ 打开 ch4 网 站 ,选择 “网 站 | 添加 新 项 "命令, 出现 “ 添 
| 加 新 项 -ch4” 对 话 框 ,在 中 间 列 表 中 选择 Web 窗 体 ”, 将 文 
| 件 名 称 改 为 WebForm2. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ” 
1 按钮 。 
| 2 @ 该 网 页 的 设计 界面 如 图 4. 6 所 示 , 其 中 包含 两 个 标 
st |e 折 分 |。 源 | | <aspTextD|] 签 (ID 为 Labell 和 Label2)、 两 个 文本 框 (ID 为 TextBoxl 
和 TextBox2) 和 一 个 命令 按钮 Buttonl 。 

@ 双击 Buttonl 控件 ,出 现代 码 编辑 窗口 ,输入 以 下 事 


图 4.6 WebForm2 网 页 设计 界面 


件 过 程 代码 : 


protected void Button1_Click(object sender, EventArgs e) 
{ intn,i=1,s=0; 
if (TextBox1. Text!= "") 
个 n = int.Parse(TextBoxl.Text); 
while (i<= n) 
1 和 = 
i 
} 
TextBox2. Text = string. Format("{0}",s); 


} 
其 中 ,TextBox2. Text 二 string. Format("{0)",s) 语 句 表示 将 整 型 变量 * 的 值 转换 成 字 
符 串 后 在 TextBox2 文本 框 中 输出 n。 


@ 单 击 工 具 栏 中 的 p> Intermet Explorer 按钮 运行 本 网 页 ,在 n 文本 框 中 输入 10, 单 击 “ 计 算 ” 
按钮 , 求 得 1 到 10 之 和 为 55, 如 图 4.7 所 示 。 


2. do-while 语句 
do-while 语句 的 一 般 语法 格式 如 下 : 
do 
{ 语句 ; 
} while (条 件 表达 式 ); 
do-while 语句 每 一 次 循环 执行 一 次 “语句 ”, 然 后 计算 
“条 件 表达 式 ” 是 否 为 True, 如果 是 , 则 继续 执行 循环 ,否则 
结束 循环 。 与 while 语句 不 同 的 是 ,do-while 循环 中 的 “ 语 
名 ”至 少 会 执行 一 次 ,而 while 语句 若 条 件 第 一 次 就 不 满足 ， 
语句 一 次 也 不 会 被 执行 。 
例如 ,可 以 将 例 4. 2 的 Buttonl_Click 事件 过 程 等 价 地 改 为 : 
protected void Button1_Click(object sender, EventArgs e) 
{ int n,i=1,s=0; 
if (TextBox1. Text!= "") 
{ n= int.Parse(TextBoxl.Text); 
do 
{ s+t= i 
} while (i <= n); 
TextBox2. Text = string.Format("{0}",s); 


4.7 WebForm2 网 页 运行 界面 


} 

3. for 语句 

for 语句 通常 用 于 预先 知道 循环 次 数 的 情况 ,其 一 般 语 法 格式 如 下 : 

for (表达 式 1; 表 达 式 2; 表 达 式 3) 语 句 ; 

其 中 “表达 式 1” 可 以 是 一 个 初始 化 语句 ,一 般 用 于 对 一 组 变量 进行 初始 化 或 赋值 。“ 表 
达 式 2” 用 作 循 环 的 条 件 控 制 , 它 是 一 个 条 件 或 逻辑 表达 式 , 当 其 值 为 True 时 ,继续 下 一 次 循 
环 , 当 其 值 为 False 时 , 则 终止 循环 .“ 表 达 式 3” 在 每 次 循环 执行 完 后 执行 ,一般 用 于 改变 控制 
循环 的 变量 。 “语句 ”在 “表达 式 2” 为 True 时 执行 。 具 体 来 说 ,for 循环 的 执行 过 程 为 : 

QO 执行 “表达 式 1”。 

@ 计算 “表达 式 2” 的 值 。 

@ 如 果 “ 表 达 式 2” 的 值 为 True, 先 执行 后 面 的 “语句 ”, 再 执行 “表达 式 3”, 然 后 转向 步 
又 @; 如 果 “ 表 达 式 2” 的 值 为 False, 则 结束 整个 for 循环 。 

例如 ,可 以 将 例 4.2 的 Buttonl_Click 事件 过 程 等 价 地 改 为 : 


protected void Button1_Click(object sender, EventArgs e) 
{ int n,i,s=0; 
if (TextBox1. Text!= "") 
* n = int.Parse(TextBoxl.Text); 
for (i=1;i<=n;i+t+) 
S += i; 
TextBox2. Text = string.Format("{0}",s); 


} 
另外 ,C# 还 提供 了 foreach 循环 语句 , 它 与 for 循环 语句 类 似 ,用 于 对 容器 中 的 元 素 进行 
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遍历。 其 使 用 语法 格式 如 下 : 
foreach( 数 据 类 型 ”标识 符 in 表达 式 ) 
语句 ; 
其 中 ,“ 表 达 式 ”指定 要 遍历 的 容器 ,包括 C# 数组 ,System. Collection 名 称 空间 的 集合 以 
及 用 户 定义 的 集合 等 。 例 如 : 
int[] a= {1,2,3}; 


foreach( int t in a) // 每 执行 一 次 ,循环 变量 t 依次 取 集 合 中 的 一 个 元 素 
t 


// 对 变量 上 进行 读 操作 

} 

上 述 代码 的 运行 效果 就 是 依次 遍历 数组 a 的 所 有 元 素 ,将 数组 a 的 各 元 素 依次 赋值 给 变 
量 1。 

4. break 和 continue 语句 

break 语句 将 使 程序 从 当前 的 循环 语句 (do、while 和 for) 内 跳 转 出 来 ,接着 执行 循环 语句 
后 面 的 语句 。 

continue 语句 也 用 于 循环 语句 , 它 类 似 于 break ,但 它 不 是 结束 整个 循环 ,而 是 结束 循环 请 
句 的 当前 一 次 循环 ,接着 执行 下 一 次 循环 。 在 while 和 do-while 循环 语句 中 ,执行 控制 权 转 至 
对 “条 件 表达 式 ” 的 判断 ,在 for 语句 中 , 转 去 执行 “表达 式 2”。 


4.6 数组 


数组 是 同一 类 型 的 数据 的 有 序 结合 ,分 为 一 维 数组 、 二 维 数组 和 多 维 数组 等 。 本 节 以 一 维 
数组 为 例 说 明 C# 数 组 的 使 用 方法 ,其 他 类 型 的 数组 类 似 。 


4.6.1 一 维 数 组 的 定义 


定义 一 维 数组 的 语法 格式 如 下 : 

数组 类 型 [] 数组 名 ; 

其 中 ,“ 数 据 类 型 "为 C# 中 合法 的 数据 类 型 “数组 名 ”为 C# 中 合法 的 标识 符 。 
例如 ,以 下 定义 了 3 个 一 维 数组 , 即 整 型 数组 a、 双 精度 数组 5 和 字符 串 数组 c: 


int[] a; 

double[ ] b; 

string[ ] ¢; 

在 定义 数组 后 ,必须 对 其 进行 初始 化 才能 使 用 。 初 始 化 数组 有 两 种 方法 , 即 动态 初始 化 和 
静态 初始 化 。 


4.6.2 一 维 数组 的 动态 初始 化 


动态 初始 化 需要 借助 new 运算 符 , 为 数组 元 素 分 配 内 存 空间 ,并 为 数组 元 素 赋 初 值 ,数值 
类 型 初始 化 为 0\ 布 尔 类 型 初始 化 为 False .字符 串 类 型 初始 化 为 null。 

动态 初始 化 数组 的 格式 如 下 : 

数组 类 型 [] 数组 名 =new 数据 类 型 [n]{ 元 素 值 0, 元 素 值 1,…, 元 素 值 a- 1}; 


其 中 ,“ 数 组 类 型 "是 数组 中 数据 元 素 的 数据 类 型 ,n 为 “数组 长 度 ”, 可 以 是 整 型 常量 或 变 
量 ,后 面 一 层 大 括号 为 初始 值 部 分 。 


4.6.3 访问 一 维 数 组 中 的 元 素 


为 了 访问 一 维 数组 中 的 某 个 元 素 , 需 指定 数组 名 称 和 数组 中 该 元 素 的 下 标 ( 或 索引 )。 
有 元 素 下 标 从 0 开始 到 数组 长 度 减 1。 例 如 ,以 下 语句 输出 数组 a 的 所 有 元 素 值 : 


for (i=0;i<5;i++) 


// 输 出 a[i] 的 值 ; 


4.7 蜡 常 处 理 语句 和 命名 空间 


4.7.1 异常 处 理 语句 


为 了 保证 程序 更 加 完备 ,用 户 会 经 常 在 程序 中 使 用 到 异常 处 理 语句 try-catch-finally, 其 
使 用 语法 格式 如 下 : 


try 

{ 被 保护 的 语句 块 ; } 
catch( 异 常 对 象 声 明 ) 

{ 捕获 到 异常 时 执行 的 语句 块 ; } 
finally 


{ 完成 善后 工作 的 语句 块 ; } 
其 中 ,各 部 分 的 说 明 如 下 。 
。 try 块 : 封装 了 程序 要 执行 的 代码 ,如 果 执 行 这 段 代 码 的 过 程 中 出 现 错误 或 者 异常 情 
况 ,就 会 抛 出 一 个 异常 。 
。 catch 块 : 在 try 块 的 后 面 封装 了 处 理 在 try 代码 块 中 出 现 的 错误 所 采取 的 措施 ,可 以 
有 多 个 catch 块 用 来 捕获 不 同类 型 的 异常 。 
。 finally 块 : 该 块 是 可 选 的 ,如 果 有 , 放 在 catch 之 后 ,无 论 try 块 是 否 有 异常 ,这 个 块 中 
的 代码 都 要 执行 。 另 外 不 能 跳出 finally 块 ,如 果 采 用 跳 转 语句 要 跳出 try 块 , 仍 要 执 
行 finally 块 。 
【 例 4.3】 在 ch4 网 站 中 设计 一 个 检测 两 个 整数 除法 运算 错误 的 网 页 WebForm3, 做 除 
法 运算 的 两 个 正 整 数 由 用 户 输 入 。 
解 : 其 步骤 如 下 。 
@ 打开 ch4 网 站 ,选择 “网 站 | 添加 新 项 "命令 ,出 现 “ 添 
加 新 项 -ch4” 对 话 框 ,在 中 间 列 表 中 选择 "Web 窗 体 ”, 将 文 
件 名 称 改 为 WebForm3. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ” 
按钮 。 
@ 该 网 页 的 设计 界面 如 图 4. 8 所 示 , 其 中 包含 3 个 标 
签 (ID 为 Labell 一 Label3)、3 个 文本 框 (ID 为 TextBoxl 一 
TextBox3) 和 一 个 命令 按钮 Button1l 。 和 上 
@ 双击 Buttonl 控件 ,出 现代 码 编辑 窗口 ,输入 以 下 事 上 呈 1* 革 ee 
件 过 程 代码 : 图 4.8 ”WebForm3 网 页 设计 界面 
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protected void Buttonl_ Click(object sender, EventArgs e) 
{ inta, b, c; 
string mystr = ""; 
try 
{ a = int.Parse(TextBoxl.Text); 
b = int.Parse(TextBox2.Text); 
c = a/b; 
mystr = string.Format("{0}",c); 
} 
catch(DivideByZeroException ex) 
{ 
mystr =“" 除 零 错误 "; 
} 
catch (Exception ex) 
{ 
mystr = ex.Message; 
} 
finally 
{ 
TextBox3. Text = mystr; 
} 
} 


其 中 ,DivideByZeroException 是 除 零 异常 类 ,Exception 是 异常 类 ,前 者 是 从 后 者 派生 的 。 
Exception 类 包含 Message 属性 ,在 出 现 异 常 时 包含 相应 的 错误 信息 。 

@ 单 击 工 具 栏 中 的 > Intemet Explorer 按钮 运行 本 网 页 ,在 “被 除数 "文本 框 中 输入 12, 在" 除 
数 ” 文 本 框 中 输入 4, 单 击 “ 相 除 ” 按 钮 ,其 结果 如 图 4. 9 所 示 。 在 “被 除数 "文本 框 中 输入 12 ,在 
“除数 ”文本 框 中 输入 0, 单 击 “ 相 除 ” 按 钮 , 出现 异常 ,被 第 一 个 catch 子 句 检测 到 ,会 修改 
mystr 的 值 ,其 结果 如 图 4. 10 所 示 。 从 中 看 到 ,不 论 是 否 出 现 异常 ,都 会 执行 finally 中 包含 的 
语句 。 


所 ® 馈 http://localhost5380 吕 0 
愿 localhost x 


被 除数 [12 


除 教 


[Li 除 ] 
个 采 SR 


图 4.9 WebForm3 网 页 运行 界面 一 图 4.10 ”WebForm3 网 页 运行 界面 二 


4.7.2 使 用 命名 空间 


在 C# 编 程 中 总 会 使 用 到 .NET 类 库 , 它 是 一 个 含有 上 千 个 类 、 接 口 和 值 类 型 的 库 , 提 供 
了 对 系统 功能 的 访问 ,是 创建 Web 应 用 程序 等 的 基础 。 其 中 所 有 的 类 按 逻 辑 关 系 进 行 分 类 ， 
也 就 是 命名 空间 ,命名 空间 提供 了 一 种 组 织 相关 类 和 其 他 类 型 的 方式 。 与 文件 或 组 件 不 同 , 命 
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名 空间 是 一 种 逻辑 组 合 ,而 不 是 物理 组 合 。 在 C# 文 件 中 定义 类 时 ,可 以 把 它 包括 在 命名 空间 
定义 中 。 以 后 再 定义 另 一 个 类 ,在 另 一 个 文件 中 执行 相关 操作 时 ,就 可 以 在 同一 个 命名 空间 中 
包含 它 , 创 建 一 个 逻辑 组 合 ,告诉 使 用 类 的 其 他 开发 人 员 这 两 个 类 是 如 何 相 关 的 以 及 如 何 使 用 
它们 。 

使 用 命名 空间 有 两 种 方式 ,一 种 是 使 用 别名 指令 为 命名 空间 定义 别名 ,这 样 此 后 的 程序 语 
句 就 可 以 使 用 这 个 别名 来 代替 定义 的 这 个 命名 空间 ; 另 一 种 是 通过 using 关键 字 引 用 命名 空 
间 , 把 该 命名 空间 中 的 类 型 导入 到 包含 这 个 using 语句 的 命名 空间 中 ,这 样 就 可 以 直接 使 用 命 
名 空间 中 的 类 型 的 名 称 。 例 如 : 


using System; 


这 个 语句 就 是 引用 System 命名 空间 ,这 样 在 程序 中 就 可 以 使 用 System 命名 空间 中 包含 
的 类 或 结构 体 等 。 在 前 面 的 所 有 示例 中 ,进入 代码 编辑 窗口 时 ,其 开头 部 分 默认 包含 以 下 
语句 : 

using System; 

using System. Collections. Generic; 

using System. Ling; 

using System. Web; 

using System. Web. UI; 

using System. Web. UI. WebControls; 

这 是 引用 .NET Framework 的 命名 空间 ,其 说 明 如 下 。 

。 System: 提供 基本 类 。 

。 System. Collections. Generic: 提供 集合 类 。 
System. Linq: 提供 用 于 LINQ 的 类 。 

。 System. Web: 提供 使 浏览 器 与 服务 器 相互 通信 的 类 和 接口 。 

。 System. Web. UI: 提供 用 于 创建 Web 应 用 程序 用 户 界面 的 类 和 接口 。 

。 System. Web. UI. WebControls: 提供 在 Web 窗 体 上 创建 Web 服务 器 控件 的 类 。 

对 于 这 些 网 页 的 设计 ,只 需要 引用 System 命名 空间 就 可 以 了 。 开 发 人 员 可 以 根据 需要 
添加 或 修改 ,大 家 在 后 面 的 章节 中 会 看 到 特定 命名 空间 的 添加 。 


4.8 面向 对 象 程序 设计 


C# 是 一 种 纯 面 向 对 象 的 程序 设计 语言 ,本 节 介绍 C# 中 的 类 及 其 成 员 设计 。 
2 

从 计算 机 语言 角度 来 说 ,类 是 一 种 数据 类 型 ,而 对 象 是 具有 这 种 类 型 的 变量 。 

1. 类 的 声明 

声明 类 的 语法 格式 如 下 : 

[类 的 修饰 符 ] class 类 名 [: 基 类 名 ] 

{ 


// 类 的 成 员 ; 
}[;] 


其 中 ,class 是 声明 类 的 关键 字 ,“ 类 名 ”必须 是 合法 的 C# 标识 符 。“ 类 的 修饰 符 ”" 有 多 种 ， 
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用 于 指定 类 的 访问 级 别 , 其 说 明 如 表 4. 5 所 示 。 


表 4.5 类 的 访问 修饰 符 


类 的 修饰 符 说 明 
public 公有 类 ,表示 对 该 类 的 访问 不 受 限制 
protected 保护 类 ,表示 只 能 从 所 在 类 和 所 在 类 派生 的 子 类 进行 访问 
internal 内 部 类 ,只 有 其 所 在 类 才能 访问 
private 私有 类 ,只 有 该 类 才能 访问 
abstract 抽象 类 ,表示 该 类 是 一 个 不 完整 的 类 ,不 允许 建立 类 的 实例 
sealed 密封 类 ,不 允许 从 该 类 派生 新 的 类 


例如 ,以 下 声明 了 一 个 Person 类 : 


public class Person // 声 明 Person 类 ,其 访问 级 别 为 public 
{ public int pno; // 编 号 公有 字段 
string pname; // 姓 名 私有 字段 


public void setdata( int no, string name) // 定 义 setdata 方 法 


{ 


pno = no; pname = name; 


public void dispdata( ) // 定 义 dispdata 方 法 


{ 
} 


Console. WriteLine("{0} {1}", pno, pname); } 


2. 类 的 成 员 

类 的 成 员 可 以 是 类 本 身 所 声明 的 以 及 从 基 类 中 继承 而 来 的 。 类 的 成 员 如 表 4. 6 所 示 ,总 
体 上 分 为 两 大 类 , 即 字段 和 属性 合 起 来 称 为 数据 成 员 ,主要 用 于 存储 类 的 数据 ; 其 他 合 起 来 称 
为 函数 成 员 ,主要 用 于 数据 的 处 理 或 操作 。 


表 4.6 类 的 成 员 

类 的 成 员 说 明 

字段 字段 存储 类 要 满足 其 设计 所 需要 的 数据 ,也 称 为 数据 成 员 

属性 属性 是 类 中 可 以 像 类 中 的 字段 一 样 访 问 的 方法 。 属 性 可 以 为 类 字段 提供 保护 ,避免 字段 在 
对 象 不 知道 的 情况 下 被 更 改 

方法 方法 定义 类 可 以 执行 的 操作 。 方 法 可 以 接受 提供 输入 数据 的 参数 ,并 且 可 以 通过 参数 返回 
输出 数据 。 方 法 还 可 以 不 使 用 参数 而 直接 返回 值 

委托 委托 定义 了 方法 的 类 型 ,使 得 可 以 将 方法 当 作 另 一 个 方法 的 参数 来 进行 传递 ,这 种 将 方法 动 
态 地 赋 给 参数 的 做 法 使 得 程序 具有 更 好 的 可 扩展 性 

事件 事件 是 向 其 他 对 象 提供 有 关 事件 发 生 ( 如 单 击 按钮 或 成 功 地 完成 某 个 方法 ) 通 知 的 一 种 方式 

索引 器 索引 器 允许 以 类 似 于 数组 的 方式 为 对 象 建立 索引 

运算 符 运算 符 是 对 操作 数 执行 运算 的 术语 或 符号 ,如 十 、x 、 一 等 

构造 函数 。 构造 函数 是 在 第 一 次 创建 对 象 时 调用 的 方法 。 它 们 通常 用 于 初始 化 对 象 的 数据 

析 构 函数 。 析 构 函数 是 当 对 象 即 将 从 内 存 中 移 除 时 由 运行 库 执行 引擎 调用 的 方法 。 它 们 通常 用 来 确保 


需要 释放 的 所 有 资源 都 得 到 了 适当 的 处 理 


类 的 成 员 也 可 以 使 用 不 同 的 访问 修饰 符 , 从 而 定义 它们 的 访问 级 别 ,类 成 员 的 访问 修饰 符 
及 其 说 明 如 表 4.7 所 示 。 
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表 4.7 类 成 员 的 访问 修饰 符 


类 成 员 的 修饰 符 说 明 

public 公有 成 员 ,提供 了 类 的 外 部 界面 ,允许 类 的 使 用 者 从 外 部 进行 访问 ,这 是 限制 最 少 
的 一 种 访问 方式 

Private 私有 成 员 ( 默 认 的 ), 仅 限于 类 中 的 成 员 可 以 访问 ,从 类 的 外 部 访问 私有 成 员 是 不 合 
法 的 ,如 果 在 声明 中 没有 出 现成 员 的 访问 修饰 符 , 按 照 默认 方式 成 员 为 私有 的 

protected 保护 成 员 , 这 类 成 员 不 允许 外 部 访问 ,但 允许 其 派生 类 成 员 访问 

internal 内 部 成 员 ,允许 同一 个 命名 空间 中 的 类 访问 

readonly 只 读 成 员 , 这 类 成 员 的 值 只 能 读 ,不 能 写 。 也 就 是 说 ,除了 赋 子 初始 值 外 ,在 程序 的 


任何 一 个 部 分 将 无 法 更 改 这 个 成 员 的 值 


例如 ,前 面 声明 的 Person 类 对 应 的 类 图 如 图 4. 11 所 示 , 字 
段 和 方法 前 面 的 图 标 表示 该 成 员 的 访问 级 别 。 

C# 中 的 类 声明 和 C++ 有 一 个 明显 的 差别 就 是 字段 可 以 赋 初 
值 ,例如 ,在 前 面 Person 类 的 声明 中 可 以 将 pno 字段 改 为 : 


public int pno = 101; ® dispdata 
日 setdata 
这 样 Person 类 的 每 个 对 象 的 pno 字段 都 有 默认 值 101。 


3. 分 部 类 图 4.11 Person 类 的 类 图 

分 部 类 可 以 将 类 (结构 体 或 接口 等 ) 的 声明 拆 分 到 两 个 或 多 
个 源 文件 中 。 若 要 拆 分 类 的 代码 ,被 拆 分 类 的 每 一 部 分 的 定义 前 面 都 要 用 partial 关键 字 修 
饰 。 分 部 类 的 每 一 部 分 都 可 以 存放 在 不 同 的 文件 中 ,编译 时 会 将 所 有 部 分 组 合 起 来 构成 一 个 
完整 的 类 声明 。 

每 个 网 页 的 逻辑 代码 中 都 声明 了 一 个 分 部 类 ,例如 WebForml 网 页 的 逻辑 代码 
WebForml. aspx. cs 中 有 以 下 代码 : 

public partial class WebForml : System. Web.UI.Page 

{ 


} 

表示 WebForml 类 是 一 个 分 部 类 , 它 是 从 System. Web. UI. Page 类 派生 的 。 实 际 上 ,所 
有 网 页 类 都 是 从 System. Web. UI. Page 类 继承 的 ,ASP. NET 将 动态 编译 网 页 ,并 在 用 户 第 一 
次 请 求 时 运行 网 页 ,如 果 网 页 发 生 更 改 , 编 译 器 将 自动 对 该 网 页 进行 重新 编译 。 


4.8.2 对 象 


类 和 对 象 是 不 同 的 概念 。 类 定义 对 象 的 类 型 ,但 它 不 是 对 象 本 身 。 对 象 是 基于 类 的 具体 
实体 ,有 时 称 为 类 的 实例 。 只 有 在 定义 类 对 象 时 才 会 给 对 象 分 配 相应 的 内 存 空 间 。 

1. 定义 类 的 对 象 

一 旦 声明 了 一 个 类 ,就 可 以 用 它 作为 数据 类 型 来 定义 类 对 象 (简称 为 对 象 )。 定 义 类 的 对 
象 分 两 步 : 

(1) 定义 对 象 引用 

其 语法 格式 如 下 : 

类 名 ”对象 名 ; 
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例如 ,“Person p;” 语 句 定义 Person 类 的 对 象 引 用 p。 

(2) 创建 类 的 实例 

其 语法 格式 如 下 : 

对 象 名 =new 类 名 (); 

例如 ,“p 二 new Person();” 语 句 创 建 Person 类 的 对 象 实例 。 

以 上 两 步 也 可 以 合并 成 一 步 。 其 语法 格式 如 下 : 

类 名 ”对象 名 = new 类 名 (); 

例如 “Person p 王 new Person();” 语 句 。 

通常 将 对 象 引 用 和 对 象 实例 混用 ,但 读者 应 了 解 它们 之 间 的 差异 。 在 上 述 语 句 中 Person() 
部 分 是 创建 类 的 实例 ,然后 传递 回 该 对 象 的 引用 并 赋 给 p, 这 样 就 可 以 通过 对 象 引用 p 操作 该 
对 象 实例 。 两 个 对 象 引用 可 以 引用 同一 个 对 象 ,例如 : 


Person pl 
Person p2 


在 上 述 代码 中 先 创 建 一 个 Person 对 象 引用 pl, 再 创建 一 个 Person 类 实例 ,由 pl 指向 该 
实例 ,在 执行 p2==pl 后 ,两 个 对 象 引 用 pl、p2 指向 同一 个 实例 。 

2. 访问 对 象 的 字段 

访问 对 象 字段 的 语法 格式 如 下 : 

对 象 名 .字段 名 

其 中 ,“. "是 一 个 运算 符 ,该 运算 符 的 功能 是 表示 对 象 的 成 员 。 

例如 ,前 面 定 义 的 p 对 象 的 成 员 变量 表示 为 p. pno。 

实际 上 ,通过 对 象 名 只 能 访问 类 的 公有 成 员 , 不 能 访问 类 的 私有 成 员 或 保护 成 员 。 由 于 
Person 类 的 pname 字段 默认 是 私有 的 ,所 以 不 能 像 p. pname 这 样 访问 pname 字段 。 

3. 调用 对 象 的 方法 

调用 对 象 的 方法 的 语法 格式 如 下 : 

对 象 名 .方法 名 (参数 表 ) 

例如 ,调用 前 面 定义 的 p 对 象 的 成 员 方 法 setdata 为 p. setdata(101,"Mary") 。 

【 例 4.4】 在 ch4 网 站 中 设计 一 个 网 页 WebForm4 ,说 明 类 设计 方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch4 网 站 ,选择 “网 站 | 添加 新 项 命令, 出现“ 添加 新 项 -ch4” 对 话 框 ,在 中 间 列 表 中 
选择 “Web 窗 体 ”, 将 文件 名 称 改 为 WebForm4. aspx, 其 他 保持 默认 项 , 单 击 “添加 ”按钮 ,创建 
一 个 空 的 网 页 。 

@ 选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 ”对 话 框 ,从 模板 列表 中 选择 “类 ”选项 , 保 
持 默认 类 文件 名 Classl. cs, 如 图 4. 12 所 示 , 单 击 “ 添 加 ”按钮 ,此 时 出 现 如 图 4. 13 所 示 的 系统 
消息 框 , 单 击 “是 ?按钮 ,表示 将 该 类 文件 放 在 系统 自动 创建 的 App_Code 目录 中 ,设计 Classl 
类 的 代码 如 下 : 


public class Classl 
{ int xh= 0; 
string xm= ""; 
public void setdatal( int xhl, string xml) 


new Person( ); 
pl; 


{ xh= xhl; xm = xml; } 
public int getxh() 

{ return xh; } 

public string getxm() 

{ return xm; } 


口 将 人 王族 在 单 儿 的 文件 中 (P) 
DOD RSAO 


EE | 


图 4.12 “添加 新 项 ”对 话 框 


ve 


( 潜 ) 添 加 到 ASP.NET 网 站 。 通 常 ， 要 在 网 站 
中 使 用 此 关 型 的 项 ,应 构 其 放 在 “App_Code” 文 件 夹 中 。 旺 否 格 该 文 


件 放 在 “App_Code” 文件 夹 中 ? 


Eas) sme) ee 


图 4.13 系统 消息 框 


@ 保存 该 文件 后 设计 WebForm3 网 页 的 界面 如 图 4. 14 所 示 , 其 中 包含 两 个 标签 (ID 为 
Labell 和 Label2) 两 个 文本 框 (ID 为 TextBoxl 和 TextBox2) 和 一 个 命令 按钮 Buttonl ,并 将 


两 个 文本 框 的 ReadOnly 属性 设置 为 True。 
@ 双击 Buttonl 控件 ,出 现代 码 编辑 窗口 ,输入 以 下 事件 过 程 代 码 : 


Protected void Button1_Click(object sender, EventArgs e) 


{ Classl st=newClassl(); // 定 义 类 对 象 st 
st. setdata(101, " 王 华 "); // 调 用 方法 
TextBoxl.Text = string.Format("{0}", st.getxh()); 
TextBox2. Text = st.getxm(); 
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@ 单 击 工 具 栏 中 的 P Internet Explorer 按钮 运行 本 网 页 , 单 击 “ 显 示 ” 按 钮 ,其 运行 结果 如 
图 4.15 所 示 。 


Classl.cs 


[eo lS) 儿 hapynacalhost5380 po 
学 号 : 铺 localhost x 

姓名 : 对 号 : [101 

,显示 | 姓名 : [EE 

a 显示 

设计 |a 拆 分 |“。 源 | [| <asp:ButtonzBu|》] | 

图 4.14 WebForm4 网 页 设计 界面 图 4.15 WebForm4 网 页 运行 界面 


4.8.3 构造 函数 和 析 构 函数 


类 的 构造 函数 和 析 构 函数 都 是 类 的 成 员 方法 ,但 它们 有 着 特殊 性 。 
1. 构造 函数 
构造 函数 是 在 创建 给 定 类 型 的 对 象 时 执行 的 类 方法 。 构 造 函 数 具有 以 下 性 质 : 
。 构造 函数 的 名 称 与 类 的 名 称 相 同 。 
。 构造 函数 尽管 是 一 个 函数 ,但 没有 任何 类 型 , 即 它 既 不 属于 返回 值 函 数 也 不 属于 void 
函数 。 
一 个 类 可 以 有 多 个 构造 函数 ,但 所 有 构造 函数 的 名 称 都 必须 相同 ,它们 的 参数 各 不 相 
同 , 即 构造 函数 可 以 重 载 。 
当 创 建 类 对 象 时 ,构造 函数 会 自动 地 执行 ; 由 于 它们 没有 返回 类 型 ,不 能 像 其 他 函数 
那样 进行 调用 。 
当 声 明 类 对 象 时 ,调用 哪 一 个 构造 函数 取决 于 传递 给 它 的 参数 类 型 。 

。 构造 函数 不 能 被 继承 。 

。 当 定 义 类 对 象 时 ,构造 函数 会 自动 执行 。 因 为 一 个 类 可 能 会 有 包括 默认 构造 函数 在 内 

的 不 止 一 种 构造 函数 ,下 面 讨论 如 何 调用 特定 的 构造 函数 。 

(1) 调用 默认 构造 函数 

不 带 参数 的 构造 函数 称 为 “默认 构造 函数 ”。 无 论 何 时 ,只 要 使 用 new 运算 符 实例 化 对 
象 ,并 且 不 为 new 提供 任何 参数 ,就 会 调用 默认 构造 函数 。 假 设 一 个 类 包含 有 默认 构造 函数 ， 
调用 默认 构造 函数 的 语法 如 下 : 

类 名 对象 名 = new 类 名 (); 

如 果 没 有 为 对 象 提供 构造 函数 , 则 默认 情况 下 C# 将 创建 一 个 构造 函数 ,该 构造 函数 实例 
化 对 象 ,并 将 所 有 成 员 变量 设置 为 相应 的 默认 值 。 

(2) 调用 带 参 数 的 构造 函数 

假设 一 个 类 中 包含 有 带 参 数 的 构造 函数 ,调用 这 种 带 参 数 的 构造 函数 的 语法 如 下 : 

类 名 ”对象 名 = new 类 名 (参数 表 ); 

其 中 ,“ 参 数 表 ”中 的 参数 可 以 是 变量 ,也 可 以 是 表达 式 。 

【 例 4.5】 在 ch4 网 站 中 设计 一 个 网 页 WebForm5 ,采用 构造 函数 方式 实现 与 例 4.4 网 


页 相同 的 功能 。 

解 : 其 步骤 如 下 。 

@ 打开 ch4 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch4” 对 话 框 ,在 中 间 列 表 中 
选择 "Web 窗 体 ”, 将 文件 名 称 改 为 WebForm5. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 ,创建 
一 个 空 的 网 页 。 

@ 打开 Classl. cs 文件 ,输入 以 下 代码 


public class Class2 
{ int xh = 0; 


string xm = 
public Class2(int xhl, string xml) // 构 造 函数 
{ xh= xhl; xm = xml; } 
public int getxh() 
{ returnxh; } 
public string getxm() 
{ returnxm; } 
} 
@ 将 WebForm4 网 页 设计 界面 复制 到 本 网 页 中 ,然后 双击 Buttonl 控件 ,出 现代 码 编 辑 
窗口 ,输入 以 下 事件 过 程 代码 : 
protected void Button1_Click(object sender, EventArgs e) 
{ Class2 st = new Class2(101," 王 华 "); 
TextBoxl.Text = string.Format("{0}", st.getxh()); 
TextBox2.Text = st.getxm(); 
} 
本 网 页 的 运行 结果 与 WebForm4 网 页 相同 。 
2. 析 构 函数 
当 对 象 不 再 需要 时 ,希望 它 所 占 的 存储 空间 能 被 收回 。 在 C# 中 提供 了 析 构 函数 专门 用 
F 释 放 被 占用 的 系统 资源 。 析 构 函 数 具有 以 下 性 质 : 
。 析 构 函 数 在 类 对 象 销毁 时 自动 执行 。 
。 一 个 类 只 能 有 一 个 析 构 函数 ,而 且 析 构 函 数 没有 参数 , 即 析 构 函数 不 能 重 载 。 
。 析 构 函 数 的 名 称 是 "一 ”加 上 类 的 名 称 (中 间 没 有 空格 )。 
。 与 构造 函数 一 样 , 析 构 函数 也 没有 返回 类 型 。 
。 析 构 函 数 不 能 被 继承 。 


4.8.4 属性 


属性 描述 了 对 象 的 具体 特性 , 它 提供 了 对 类 或 对 象 成 员 的 访问 。C# 中 的 属性 更 充分 地 
体现 了 对 象 的 封装 性 ,不 直接 操作 类 的 字段 ,而 是 通过 访问 器 进行 访问 。 

属性 在 类 模块 里 是 采用 以 下 方式 进行 声明 的 , 即 指定 变量 的 访问 级 别 . 属 性 的 类 型 .属性 
的 名 称 , 然 后 是 get 访问 器 或 者 set 访问 器 代码 块 。 其 语法 格式 如 下 : 

修饰 符 数据 类 型 属性 名 称 


{ ”get 访问 器 // 设 置 该 属性 是 可 读 的 
set 访问 器 // 设 置 该 属性 是 可 写 的 


} 
属性 是 通过 “访问 器 "来 实现 的 : 访问 器 是 数据 字段 赋值 和 检索 其 值 的 特殊 方法 。 使 用 
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set 访问 器 可 以 为 数据 字段 赋值 ,使 用 get 访问 器 可 以 检索 数据 字段 的 值 。 

属性 是 为 了 保护 类 的 字段 。 通 常情 况 下 ,将 字段 设计 为 私有 的 ,设计 一 个 对 其 进行 读 或 写 
的 属性 。 在 属性 的 get 访问 器 中 用 return 来 返回 该 字段 的 值 ,在 属性 的 set 访问 器 中 可 以 使 
用 一 个 特殊 的 隐 含 参数 value ,该 参数 包含 用 户 指定 的 值 。 

【 例 4.6】 在 ch4 网 站 中 设计 一 个 网 页 WebForm6 ,采用 属性 方式 实现 与 例 4.4 网 页 相 
同 的 功能 。 

解 : 其 步骤 如 下 。 

@ 打开 ch4 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch4” 对 话 框 ,在 中 间 列 表 中 
选择 Web 窗 体 ”, 将 文件 名 称 改 为 WebForm6. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 ,创建 
一 个 空 的 网 页 。 

@ 打开 Classl. cs 文件 ,输入 以 下 代码 ; 


public class Class3 
{ int xh = 0; 
string xm = 
public int pxh // 属 性 pxh 
{ get{ returnxh;} 
set{ xh = value; } 


} 
public string pxm // 属 性 pxm 
{ get{ return xm; } 
set{ xm = value; } 
} 
} 


@ 将 WebForm4 网 页 设计 界面 复制 到 本 网 页 中 ,然后 双击 Buttonl 控件 ,出 现代 码 编 辑 
窗口 ,输入 以 下 事件 过 程 代码 : 
protected void Button1_Cl ick(object sender, EventArgs e) 
{ Class3 st = new Class3(); 
st. pxh = 101; 
st. pxm = " 王 华 "; 
TextBox1l.Text = string. Format("{0}", st.pxh); 
TextBox2. Text = st. pxm; 
} 


本 网 页 的 运行 结果 与 WebForm4 网 页 相同 。 
4.8.5 方法 


方法 是 包含 一 系列 代码 的 代码 块 。 从 本 质 上 讲 , 方 法 就 是 和 类 相关 联 的 动作 ,是 类 的 外 部 
界面 。 用 户 可 以 通过 外 部 界面 来 操作 类 的 私有 字段 。 

1. 方法 的 定义 

定义 方法 的 基本 格式 如 下 : 

修饰 符 返回 类 型 方法 名 (参数 列表 ) 

{ 


// 方 法 的 具体 实现 ; 
} 


其 中 ,如 果 省 略 “ 修 饰 符 ”, 默 认为 private。“ 返 回 类 型 ”指定 该 方法 返回 数据 的 类 型 , 它 可 


以 是 任何 有 效 的 类 型 。 如 果 方 法 不 需要 返回 一 个 值 , 其 返回 类 型 必须 是 void。“ 参 数列 表 ” 是 
用 逗号 分 隔 的 类 型 .标识 符 对 。 这 里 的 参数 是 形 参 ,本 质 上 是 变量 , 它 用 来 在 调用 方法 时 接收 
实 参 传 给 方法 的 值 ,如 果 方 法 没有 参数 ,那么 "参数 列表 ”为 空 。 

2. 方法 的 返回 值 

方法 可 以 向 调用 方 返回 某 一 特定 的 值 。 如 果 返 回 类 型 不 是 void, 则 该 方法 可 以 用 return 
关键 字 来 返回 值 ,return 还 可 以 用 来 停止 方法 的 执行 。 

3. 方法 的 参数 

方法 中 的 参数 是 保证 不 同方 法 间 互 动 的 重要 “桥梁 ”, 方 便 用 户 对 数据 的 操作 。C# 中 方 
法 的 参数 有 下 面 4 种 类 型 。 

(1) 值 参 数 

不 含 任何 修饰 符 , 当 利用 值 向 方法 传递 参数 时 ,编译 程序 给 实 参 的 值 做 一 份 副本 ,并 且 将 
此 副本 传递 给 该 方法 对 应 的 形 参 ,被 调用 的 方法 不 会 修改 内 存 中 实 参 的 值 ,所 以 使 用 值 参 数 时 
是 可 以 保证 实 参 的 安全 性 的 。 

例如 ,前 面 Classl 类 的 setdata 方法 中 的 参数 就 是 值 参数 。 

(2) 引用 型 参数 

以 ref 修饰 符 声明 的 参数 属 引 用 型 参数 。 引 用 型 参数 本 身 并 不 创建 新 的 存储 空间 ,而 是 
将 实 参 的 存储 地 址 传递 给 形 参 ,所 以 对 形 参 的 修改 会 影响 原来 的 实 参 。 在 调用 方法 前 ,引用 型 
实 参 必须 被 初始 化 ,同时 在 调用 方法 时 对 应 引用 型 参数 的 实 参 也 必须 使 用 ref 修饰 。 

例如 ,以 下 定义 的 MyClass 类 中 的 addnum 方法 使 用 了 一 个 引用 型 参数 num2: 


public class MyClass 

3 int num= 0; 
public void addnum( int numl, ref int num2) 
{ num2=num + numl; } 

} 


以 下 语句 调用 addnum 方法 时 实 参 zx 发 生 改变 : 


int x= 0) // 引 用 型 实 参 要 置 初 什 
MyClass s = new MyClass(); 
s.addnum(5, ref x); //x 的 值 变 为 5 


(3) 输出 型 参数 

以 out 修饰 符 声明 的 参数 属 输 出 参数 。 与 引用 型 参数 类 似 , 输 出 型 参数 也 不 开辟 新 的 内 
存 区 域 。 输 出 型 参数 与 引用 型 参数 的 差别 在 于 调用 方法 前 无 须 对 实 参 进行 初始 化 。 输 出 型 参 
数 用 于 传递 方法 返回 的 数据 ,out 修饰 符 后 应 跟 与 形 参 的 类 型 相同 的 类 型 ,声明 在 方法 返回 后 
传递 的 变量 被 认为 经 过 了 初始 化 。 

例如 ,以 下 定义 的 MyClass 类 中 的 addnum 方法 使 用 了 一 个 输出 参数 num2: 


public class MyClass 

二 int num= 0; 
public void addnum( int numl, out int num2) 
{ num2 = num + numl; } 


以 下 语句 调用 addnum 方法 时 实 参 zx 发 生 改变 : 


int x; // 输 出 型 实 参 不 必 置 初 值 
MyClass s = new MyClass(); 
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s.addnum(5, out x); //x 的 值 变 为 5 


(4) 数组 型 参数 

以 params 修饰 符 声 明 数 组 型 参数 ,params 关键 字 可 以 指定 在 参数 数目 可 变 处 采用 参数 
的 方法 参数 。 在 方法 声明 中 的 params 关键 字 之 后 不 允许 任何 其 他 参数 ,并 且 在 方法 声明 中 只 
允许 一 个 params 关键 字 。 数 组 型 参数 不 能 再 有 ref 和 out 修饰 符 。 

例如 ,以 下 定义 的 MyClass 类 中 的 addnum 方法 使 用 了 一 个 数组 型 参数 4: 


public class MyClass 
{ int num= 10; 
public void addnum(ref int sum, params int[] b) 
{ sum = num; 
foreach (int item in b) 
Sum += item; 


} 
以 下 语句 求实 参数 组 a 的 所 有 元 素 之 和 : 


int x = 0; 
MyClass s = new MyClass(); 


s.addnum(ref x,1,2,3); //x 的 值 为 6 
S. addnum(ref x,1,2); //x 的 值 为 3 
s.addnum(ref x,1); //x 的 值 为 1 
4. 可 选 参数 


所 谓 可 选 参 数 是 指 在 调用 方法 时 可 以 包含 这 个 参数 ,也 可 以 忽略 它 。 为 了 表明 每 个 参数 
是 可 选 的 ,需要 在 定义 方法 时 为 它 提供 参数 默认 值 。 指 定 默认 值 的 语法 和 初始 化 本 地 变量 的 
语法 一 样 。 例 如 声明 以 下 类 : 

class MyClass 

{ public int add(int a, int b = 1, int c = 2) 


{ returna+ b+c;} 


} 
该 类 中 的 add 方法 有 两 个 可 选 参数 .有 以 下 代码 : 


MyClass s = new MyClass(); 
int x = s.add(5); 

int y = s.add(5, 6); 

int z = s.add(5, 6, 7); 


计算 过 程 是 “z=5 十 1 十 2 二 8,y 二 5 十 6 十 2 二 13,z 二 5 十 6 十 7 二 18”。 从 中 看 到 , 当 可 选 参 
数 没有 给 出 实 参 时 ,自动 取 可 选 参数 的 默认 值 。 

不 是 所 有 的 参数 类 型 都 可 以 作为 默认 值 ,其 规定 如 下 : 

。 若 只 有 值 类 型 的 默认 值 在 编译 的 时 候 可 以 确定 ,就 可 以 使 用 值 类 型 作为 可 选 参 数 。 

。 只 有 在 默认 值 是 null 的 时 候 ,引用 类 型 才 可 以 作为 可 选 参数 来 使 用 。 

如 果 一 个 方法 包含 必 填 参数 、 可 选 参 数 和 params 参数 , 则 必 填 参数 必须 在 可 选 参数 之 前 
声明 ,而 params 参数 必须 在 可 选 参数 之 后 声明 。 其 一 般 格 式 如 下 : 

fun(int x,double y, **, int opl=1,double op2=2.5,…， params int [] arr) 


必 填 参数 可 选 参数 params 参 数 
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5. 方法 的 重 载 

方法 的 重 载 是 指 调用 同一 个 方法 名 .但 是 使 用 不 同 的 数据 类 型 的 参数 或 者 参数 的 次 序 不 
一 致 。 只 要 一 个 类 中 有 两 个 以 上 的 同名 方法 , 且 使 用 的 参数 类 型 或 者 个 数 不 同 ,编译 器 就 可 以 
判断 在 哪 种 情况 下 调用 了 哪 种 方法 。 

为 此 ,在 C# 中 引入 了 成 员 签 名 的 概念 。 成 员 签名 包含 成 员 的 名 称 和 参数 列表 ,每 个 成 员 
签名 在 类 型 中 必须 是 唯一 的 ,只 要 成 员 的 参数 列表 不 同 ,成 员 的 名 称 可 以 相同 。 如 果 同 一 个 类 
有 两 个 或 多 个 这 样 的 成 员 ( 方 法 、 属 性 ,构造 函 数 等 ) ,它们 具有 相同 的 名 称 和 不 同 的 参数 列表 ， 
则 称 该 同类 成 员 进 行 了 重 载 ,但 它们 的 成 员 签名 是 不 同 的 。 

例如 ,下 面 的 代码 实现 了 MethodTest 方法 的 重 载 (假设 都 是 某 个 类 的 成 员 ) ,它们 是 不 同 
的 成 员 签名 : 


public int MethodTest(int i, int j) // 重 载 方法 1 


// 代 码 
pe int MethodTest (int i) // 重 载 方法 2 
// 代 码 
2 string MethodTest(string sr) // 重 载 方法 3 
// 代 码 


4.8.6 委托 简介 

委托 是 一 种 安全 的 封装 方法 的 类 型 ,类 似 于 C /C++ 中 的 函数 指针 ,通过 委托 可 以 将 方法 
作为 参数 或 变量 使 用 ,从 而 可 以 采用 统一 的 格式 调用 多 个 方法 。 与 C/C++ 中 的 函数 指针 不 
同 ,委托 是 类 型 安全 的 。 
4.8.7 事件 简介 


事件 是 一 种 用 于 类 和 类 之 间 传 递 消息 或 触发 新 的 行为 的 编程 方式 。 事 件 可 以 看 成 类 的 委 
托 , 能 够 把 控件 和 可 执行 代码 联系 在 一 起 ,如 用 户 单 击 Button 控件 触发 Click 事件 后 就 执行 相 
应 的 事件 处 理 代码 。 

事件 的 声明 通过 委托 来 实现 。 即 先 定 义 委托 ,再 用 委托 定义 事件 ,触发 事件 的 过 程 实际 上 
是 调用 委托 。 


4.9 C# 中 的 常用 类 和 结构 体 


C# 提 供 了 各 种 功能 丰富 的 内 建 类 和 结构 体 ,其 中 有 些 类 和 结构 体 是 经 常 使 用 的 ,本 节 予 
以 介绍 。 
4.9.1 String 类 


前 面 介绍 过 , string 类 型 表示 字符 串 , 实 际 上 ,string 是 . NET Framework 中 的 String 类 
的 别名 。string 类 型 定义 了 相等 运算 符 ( 王 于 和 ! 王 ) ,用 于 比较 两 个 string 对 象 , 男 外 ,“ 十 ” 运 
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算 符 用 于 连接 字符 串 ,“[ ”运算 符 用 来 访问 string 中 的 各 个 字符 。 
String 类 位 于 System 命名 空间 中 ,用 于 字符 串 的 处 理 。String 类 的 常用 属性 如 表 4.8 所 
示 , 常 用 的 方法 如 表 4. 9 所 示 , 使 用 这 些 属性 和 方法 会 给 字符 串 的 处 理 带 来 极 大 的 方便 。 


表 4.8 String 类 的 常用 属性 及 其 说 明 


属 性 说 明 
Chars 获取 此 字符 串 中 位 于 指定 字符 位 置 的 字符 
Length 获取 此 字符 串 中 的 字符 数 
表 4.9 String 类 的 常用 方法 及 其 说 明 
方 法 方法 类 型 说 明 
Compare 比较 两 个 指定 的 String 对 象 
Concat 静态 方法 连接 String 的 一 个 或 多 个 字符 串 
Format 将 指定 的 String 中 的 每 个 格式 项 蔡 换 为 相应 对 象 的 值 的 文本 等 效 项 
非 静 态 方法 ,将 此 字符 串 与 指定 的 对 象 或 String 进行 比较 ,并 返回 两 者 相 
CompareTo _ 
对 值 的 指示 
Contains 返回 一 个 值 ,该 值 指示 指定 的 String 对 象 是 否 出 现在 此 字符 串 中 
Equals 确定 两 个 String 对 象 是 否 具有 相同 的 值 
IndexOf 返回 String 或 者 一 个 或 多 个 字符 在 此 字符 串 中 的 第 一 个 匹配 项 的 索引 
Insert 在 该 String 中 的 指定 索引 位 置 插入 一 个 指定 的 String 
Remove 上 静态 方法 从 该 String 中 删除 指定 个 数 的 字符 
Replace 将 该 String 中 的 指定 String 的 所 有 匹配 项 替换 为 其 他 指定 的 String 
pi 返回 包含 该 String 中 的 子 字符 串 (由 指定 Char 或 String 数组 的 元 素 分 
隔 ) 的 String 数组 
Substring 从 该 字符 串 中 检索 子 字符 串 
ToLower 返回 该 String 转换 为 小 写 形式 的 副本 
ToUpper 返回 该 String 转换 为 大 写 形 式 的 副本 
Trim 从 该 字符 串 的 开始 位 置 和 末尾 移 除 一 组 指定 字符 的 所 有 匹配 项 


注意 : 一 个 类 的 方法 有 静态 方法 和 非 静 态 方法 之 分 。 对 于 静态 方法 ,只 能 通过 类 名 来 调 
用 ; 对 于 非 静态 方法 , 需 通 过 类 的 对 象 来 调用 。 


4.9.2 ”Math 类 


Math 类 位 于 System 命名 空间 中 . 它 包含 了 实现 C# 中 常用 算术 运算 功能 的 方法 ,这 些 方 
法 都 是 静态 方法 ,可 通过 “Math. 方法 名 (参数 ) "来 使 用 ,其 中 常用 的 方法 如 表 4. 10 所 示 。 


表 4.10 Math 类 的 常用 方法 


方法 说 明 

Abs 返回 指定 数字 的 绝对 值 

Acos 返回 余弦 值 为 指定 数字 的 角度 

Asin 返回 正弦 值 为 指定 数字 的 角度 

Atan 返回 正切 值 为 指定 数字 的 角度 

Atan2 返回 正切 值 为 两 个 指定 数字 的 商 的 角度 


Ceiling 


返回 大 于 或 等 于 指定 数字 的 最 小 整数 
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续 表 
方 法 说 明 
Cos 返回 指定 角度 的 余弦 值 
Cosh 返回 指定 角度 的 双 曲 余弦 值 
DivRem 计算 两 个 数字 的 商 ,并 在 输出 参数 中 返回 余数 
Exp 返回 e 的 指定 次 寡 
Floor 返回 小 于 或 等 于 指定 数字 的 最 大 整数 
Log 返回 指定 数字 的 对 数 
Log10 返回 指定 数字 以 10 为 底 的 对 数 
Max 返回 两 个 指定 数字 中 较 大 的 一 个 
Min 返回 两 个 数字 中 较 小 的 一 个 
Pow 返回 指定 数字 的 指定 次 震 
Round 将 值 舍 人 到 最 接近 的 整数 或 指定 的 小 数位 数 
Sign 返回 表示 数字 符号 的 值 
Sin 返回 指定 角度 的 正弦 值 
Sinh 返回 指定 角度 的 双 曲 正弦 值 
Saqrt 返回 指定 数字 的 平方 根 
Tan 返回 指定 角度 的 正切 值 
Tanh 返回 指定 角度 的 双 曲 正切 值 
Truncate 计算 一 个 数字 的 整数 部 分 


4.9.3 Convert 类 


Convert 类 位 于 System 命名 空间 中 ,用 于 将 一 个 值 类 型 转换 成 另 一 个 值 类 型 。 这 些 方法 
都 是 静态 方法 ,可 通过 “Convert. 方法 名 (参数 ) "来 使 用 ,其 中 常用 的 方法 如 表 4. 11 所 示 。 


表 4.11 Convert 类 的 常用 方法 


方 ”法 说 明 
ToBoolean 将 数据 转换 成 Boolean 类 型 
ToDataTime 将 数据 转换 成 日 期 时 间 类 型 


Tolnt16 
Tolnt32 
Tolnt64 
ToNumber 
ToObject 
ToString 


4.9.4 _ DateTime 结构 体 


将 数据 转换 成 16 位 整数 类 型 
将 数据 转换 成 32 位 整数 类 型 
将 数据 转换 成 64 位 整数 类 型 
将 数据 转换 成 Double 类 型 
将 数据 转换 成 Object 类 型 
将 数据 转换 成 string 类 型 


DateTime 结构 体位 于 System 命名 空间 中 ,DateTime 值 类 型 表示 值 范围 在 公元 0001 年 
1 月 1 日 午夜 12:00:00 到 公元 9999 年 12 月 31 日 晚上 11:59:59 之 间 的 日 期 和 时 间 。 用 户 可 
以 通过 以 下 语法 格式 定义 一 个 日 期 时 间 变 量 : 

DateTime 日 期 时 间 变 量 = new DateTime( 年 ,月 ,日 ,时 ,分 , 秒 ); 

例如 ,以 下 语句 定义 了 两 个 日 期 时 间 变 量 : 
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DateTime dl = new DateTime(2009,10,1); 
DateTime d2 = new DateTime(2009,10,1,8,15,20); 


其 中 ,dl 的 值 为 2009 年 10 月 1 日 零点 零 分 零 秒 ,d2 的 值 为 2009 年 10 月 1 日 8 点 15 分 
20 秒 。 
DateTime 结构 体 的 常用 属性 如 表 4. 12 所 示 , 常 用 方法 如 表 4. 13 所 示 。 
表 4.12 DateTime 结构 体 的 常用 属性 


属 性 说 明 
Date 获取 此 实例 的 日 期 部 分 
Day 获取 此 实例 所 表示 的 日 期 为 该 月 中 的 第 几 天 


DayOfWeek ”获取 此 实例 所 表示 的 日 期 是 星期 几 
DayOfYear ”获取 此 实例 所 表示 的 日 期 是 该 年 中 的 第 几 天 


Hour 获取 此 实例 所 表示 日 期 的 小 时 部 分 

Millisecond 获取 此 实例 所 表示 日 期 的 毫秒 部 分 

Minute 获取 此 实例 所 表示 日 期 的 分 钟 部 分 

Month 获取 此 实例 所 表示 日 期 的 月 份 部 分 

Now 获取 一 个 DateTime 对 象 , 该 对 象 设置 为 此 计算 机 上 的 当前 日 期 和 时 间 , 表 示 为 本 地 时 间 
Second 获取 此 实例 所 表示 日 期 的 秒 部 分 

TimeOfDay ”获取 此 实例 的 当天 的 时 间 

Today 获取 当前 日 期 

Year 获取 此 实例 所 表示 日 期 的 年 份 部 分 


表 4.13 DateTime 结构 体 的 常用 方法 


方 ”法 方法 类 型 说 明 

Compare 比较 DateTime 的 两 个 实例 ,并 返回 它们 相对 值 的 指示 

DaysInMonth 静态 方法 返回 指定 年 和 月 中 的 天 数 

IsLeapYear 和 返回 指定 的 年 份 是 否 为 头 年 的 指示 

Parse 将 日 期 和 时 间 的 指定 字符 串 表示 转换 成 其 等 效 的 DateTime 

AddDays 将 指定 的 天 数 加 到 此 实例 的 值 上 

AddHours 将 指定 的 小 时 数 加 到 此 实例 的 值 上 

AddMilliseconds 将 指定 的 毫秒 数 加 到 此 实例 的 值 上 

AddMinutes 非 静态 方法 将 指定 的 分 钟 数 加 到 此 实例 的 值 上 

AddMonths 将 指定 的 月 份 数 加 到 此 实例 的 值 上 

AddSeconds 将 指定 的 秒 数 加 到 此 实例 的 值 上 

AddYears 将 指定 的 年 份 数 加 到 此 实例 的 值 上 

CompareTo 将 此 实例 与 指定 的 对 象 或 值 类 型 进行 比较 .并 返回 二 者 相对 值 的 指示 
4.10 继承 


4.10.1 什么 是 继承 


为 了 对 现实 世界 中 的 层次 结构 进行 模型 化 ,面向 对 象 的 程序 设计 技术 引入 了 继承 的 概念 。 
继承 是 面向 对 象 程序 设计 最 重要 的 特征 之 一 。 任 何 类 都 可 以 从 另外 一 个 类 继承 而 来 , 即 这 个 
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类 拥有 它 所 继承 类 的 所 有 成 员 。C# 提供 了 类 的 继承 机 制 ,但 C# 只 支持 单 继 承 不 支持 多 重 继 
承 , 即 在 C# 中 一 次 只 允许 继承 一 个 类 ,不 允许 继承 多 个 类 。 

一 个 类 从 另 一 个 类 派生 出 来 时 , 称 之 为 派生 类 或 子 类 ,被 派生 的 类 称 为 基 类 或 父 类 。 派 生 
类 从 基 类 那里 继承 特性 ,派生 类 也 可 以 作为 其 他 类 的 基 类 ,从 一 个 基 类 派生 出 来 的 多 层 类 形成 
了 类 的 层次 结构 。 

与 C++ 不 同 ,C# 中 仅 允 许 单 继 承 。 也 就 是 说 ,类 只 能 从 一 个 基 类 继承 实现 。C# 中 的 继 
承 具 有 以 下 特点 : 

。 CH 中 只 允许 单 继承 , 即 一 个 派生 类 只 能 有 一 个 基 类 。 

。 CH 中 继承 是 可 以 传递 的 ,如 果 C 从 B 派 生 ,B 从 A 派生 ,那么 C 不 仅 继承 B 的 成 员 ， 
还 继承 A 的 成 员 。 
C# 中 派生 类 可 以 添加 新 成 员 ,但 不 能 删除 基 类 的 成 员 。 
。，C# 中 派生 类 不 能 继承 基 类 的 构造 函数 和 析 构 函数 ,但 能 继承 基 类 的 属性 。 
。，C# 中 派生 类 可 以 隐藏 基 类 的 同名 成 员 ,如果 在 派生 类 隐藏 了 基 类 的 同名 成 员 , 基 类 的 
该 成 员 在 派生 类 中 就 不 能 被 直接 访问 ,只 能 通过 “base. 基 类 方法 名 ”来 访问 。 
C# 中 派生 类 对 象 也 是 基 类 的 对 象 ,但 基 类 对 象 不 一 定 是 基 派 生 类 的 对 象 。 也 就 是 说 ， 
基 类 的 引用 变量 可 以 引用 基 派 生 类 对 象 ,而 派生 类 的 引用 变量 不 可 以 引用 基 类 对 象 。 


4.10.2 派生 类 的 声明 
派生 类 的 声明 格式 如 下 : 
[类 修饰 符 ] class 派生 类 : 基 类 ; 


在 C# 中 ,派生 类 可 以 从 它 的 基 类 中 继承 字段 、 属 性、 方法 和 事件 等 ,实际 上 除了 构造 函数 
和 析 构 函数 ,派生 类 隐 式 地 继承 了 基 类 的 所 有 成 员 。 
下 面 来 看 一 个 例子 , 先 声 明 一 个 基 类 : 


classA 
{ private intn; // 私 有 字段 
protected int m; // 保 护 的 字段 
public void afun() // 公 有 方法 
// 方 法 的 代码 


} 
} 


再 声明 一 个 也 类 继承 A 类 ,注意 继承 是 用 “:” 来 表示 的 : 4 
classB:A 
{ private int x; // 私 有 字段 

public void bfun() // 公 有 方法 

{ 

// 方 法 的 代码 

} B Y 
} 类 
A.B 类 的 继承 关系 如 图 4.16 所 示 , 有 以 下 代码 ， 多 
Bb = newB(); // 定 义 对 象 并 实例 化 
Breit 图 4.16 A.B 两 个 类 的 


继承 关系 
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从 中 可 以 看 出 A 类 的 afun() 方 法 在 了 类 中 不 用 重新 编写 ,因为 也 类 继承 了 A 类 ,所 以 可 
以 通过 类 B 类 的 对 象 调用 它 。 


4.10.3 基 类 成 员 的 可 访问 性 


派生 类 将 获取 基 类 的 所 有 非 私有 数据 和 行为 以 及 新 类 为 自己 定义 的 所 有 其 他 数据 或 行 
为 。 在 前 面 的 例子 中 , 基 类 A 中 保护 的 字段 m 和 公有 方法 afun 都 被 继承 到 派生 类 也 类 中 ,这 
样 在 也 类 中 隐 含 有 保护 的 字段 mx 和 公有 方法 afun。 但 基 类 A 中 的 私有 字段 n 不 能 被 继承 到 
派生 类 B 中 。 

所 以 ,如 果 希 望 在 派生 类 中 隐藏 某 些 基 类 的 成 员 , 可 以 在 基 类 中 将 这 些 成 员 设 为 private 
访问 成 员 。 


4.10.4 使 用 sealed 修饰 符 来 禁止 继承 


C# 中 提供 了 sealed 关键 字 用 来 禁止 继承 。 如 果 要 禁止 继承 一 个 类 ,只 需要 在 声明 类 时 
加 上 sealed 关键 字 就 可 以 了 ,这 样 的 类 称 为 密封 类 。 例 如 ， 


sealed class 类 名 
{ 


t 
这 样 就 不 能 从 该 类 派生 任何 子 类 。 


4.10.5 网 页 的 继承 模型 


网 页 设计 有 代码 隐藏 模型 和 单 文件 模型 ,下 面 分 别 介绍 它们 的 继承 模型 。 

1. 代码 隐藏 网 页 的 继承 模型 

在 代码 隐藏 模型 中 ,网 页 的 标记 和 服务 器 端 元 素 ( 包 括 控件 声明 ) 位 于 . aspx 文件 中 ,而 网 
页 的 程序 代码 则 位 于 单独 的 代码 文件 中 。 该 代码 文件 包含 一 个 分 部 类 , 即 具 有 关键 字 partial 
的 类 声明 ,以 表示 该 代码 文件 只 包含 构成 该 页 的 完整 类 的 全 体 代 码 的 一 部 分 。 在 分 部 类 中 , 添 
加 应 用 程序 要 求 该 网 页 所 具有 的 代码 。 此 代码 通常 由 事件 处 理 程序 构成 ,但 是 也 可 以 包括 需 
要 的 任何 方法 或 属性 。 

以 第 1 章 的 例 1. 1 为 例 ,该 网 页 中 包含 一 个 Button 控件 Buttonl 和 一 个 Label 控件 
Labell ,在 Buttonl 上 设计 有 一 个 单 击 事件 过 程 。 其 代码 隐藏 网 页 的 继承 模型 如 下 : 

Q@ 代码 隐藏 文件 包含 一 个 继承 自 基 页 类 的 分 部 类 。 基 页 类 可 以 是 Page 类 ,也 可 以 是 从 
Page 派生 的 其 他 类 。 

@ .aspx 文件 在 @ Page 指令 中 包含 一 个 指向 代码 隐藏 分 部 类 的 Inherits 属性 。 

@ 在 对 该 网 页 进行 编译 时 ,ASP.NET 将 基于 . aspx 文件 生成 一 个 分 部 类 ,此 类 是 代码 隐 
藏 类 文件 的 分 部 类 。 生 成 的 分 部 类 文件 包含 页 控件 的 声明 。 使 用 此 分 部 类 可 以 将 代码 隐藏 文 
件 用 作 完 整 类 的 一 部 分 ,而 无 须 显 式 声 明 控件 。 

@ ASP.NET 生成 另外 一 个 从 在 步骤 加 中 生成 的 类 继承 的 类 WebForml_aspx。 生 成 的 
第 2 个 类 包含 生成 该 网 页 所 需 的 代码 。 生 成 的 第 2 个 类 和 代码 隐藏 类 将 编译 成 程序 集 , 运 行 
该 程序 集 可 以 将 输出 呈现 到 浏览 器 。 

代码 隐藏 ASP.NET 网 页 中 的 页 类 的 继承 模型 如 图 4. 17 所 示 。 


WebForm1.aspx 


<% Page Inhertit="WebForml" %> 
System. Web..Ul.Page <asp:Button ID="Button1" ... %> 
<asp:Label ID="Labell" ... %> 


继承 自 
WebForml.aspx.cs 基于 .aspx 文 件 生成 的 部 分 
public partial class WebForml : System.Web.ULPage public partial class 
: WebForml 生成 
protected void Button1_Click(object sender, 
EventArgs e) protected Button 
{ Buttonl; 
Labell.Text = "您 单 击 了 按钮 "; 
} 
继承 自 
生成 的 最 终 类 
public class WebForml_aspx : 
WebForml 生成 


最 终 输 出 


图 4.17 代码 隐藏 ASP.NET 网 页 中 的 页 类 的 继承 模型 


2. 单 文件 网 页 的 继承 模型 

在 单 文件 页 中 ,标记 、 服 务 器 端 元 素 以 及 事件 处 理 代码 全 都 
位 于 同一 个 . aspx 文件 中 。 在 对 该 网 页 进行 编译 时 ,编译 器 将 生 
成 和 编译 一 个 从 Page 基 类 派生 或 从 使 用 @Page 指令 的 Inherits 
属性 定义 的 自 定义 基 类 派生 的 新 类 。 

以 第 1 章 的 例 1. 2 为 例 , 该 网 页 为 WebForm2. aspx, 将 从 
Page 类 派生 一 个 名 为 ASP. WebForm2_aspx 的 新 类 ,生成 的 类 
中 包含 WebForm2. aspx 网 页 中 的 控件 的 声明 以 及 事件 处 理 程 
序 和 其 他 自 定义 代码 。 

在 生成 网 页 之 后 ,生成 的 类 将 编译 成 程序 集 ,并 将 该 程序 集 
加 载 到 应 用 程序 域 ,然后 对 该 网 页 类 进行 实例 化 并 执行 该 网 页 
类 以 将 输出 呈现 到 浏览 器 。 如 果 对 影响 生成 的 类 的 网 页 进行 更 
改 ( 无 论 是 添加 控件 还 是 修改 代码 ) , 则 已 编译 的 类 代码 将 失效 ， 
并 生成 新 的 类 。 

单 文件 ASP. NET 网 页 中 的 页 类 的 继承 模型 如 图 4. 18 
所 示 。 


System.Web..Ul.Page 


1 


WebForm2.aspx 


遇 最 终 输 出 


4.18 单 文件 ASP.NET 
网 页 中 的 页 类 的 继 
承 模型 
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4.11 接口 简介 


C# 不 像 C++ 那样 支持 类 的 多 继承 ,为 此 提供 了 接口 实现 C++ 中 多 继承 的 功能 。 

在 C# 中 接口 是 类 之 间 交 互 内 容 的 一 个 抽象 ,把 类 之 间 需 要 交互 的 内 容 抽 象 出 来 定义 成 
接口 ,可 以 更 好 地 控制 类 之 间 的 逻辑 交互 。 

接口 只 包含 方法 .委托 或 事件 的 签名 ,方法 的 实现 是 在 实现 接口 的 类 中 完成 的 。 例 如 ,以 
下 代码 声明 了 一 个 接口 : 

interface Ia // 声 明 接口 Ta 


T 
float getarea(); // 接 口 成 员 的 声明 
} 


其 中 getarea 方法 只 有 声明 部 分 。 设 计 一 个 Rectangle 类 实现 该 接口 : 


public class Rectangle : Ia // 类 A 继承 接口 Ia 
{ float x,y; 
public Rectangle(float x1, float y1) // 构 造 函数 
{ x= xl;y= yl; } 
public float getarea() // 隐 式 接口 成 员 实现 ,必须 使 用 public 
{ returnxxyi } 


} 
这 样 ,就 可 以 定义 Rectangle 类 的 对 象 并 调用 getarea 方法 了 : 


Rectangle boxl = new Rectangle(2.5, 3.0); ”// 定 义 一 个 类 实例 
TextBoxl. Text = boxl.getarea(); // 文 本 框 中 显示 长 方形 面积 为 7.5 


一 个 接口 可 以 从 零 个 或 多 个 接口 中 继承 。 一 个 接口 可 以 被 多 个 类 继承 ,在 这 些 类 中 实现 
该 接口 的 成 员 ,这 样 接口 就 起 到 提供 统一 界面 的 作用 。 


4.12 程序 调试 


C# 提 供 了 强大 的 程序 调试 功能 ,使 用 其 调试 环境 可 以 有 效 地 完成 程序 的 调试 工作 ,从 而 
有 助 于 发 现 程序 执行 错误 。 
4.12.1 调试 工具 
1.“ 调 试 ?工具 栏 
选择 “视图 | 工具 栏 | 调试 命令, 出现“ 调试 ?工具 栏 ,如 图 4.19 所 示 。 
停止 调试 刷新 逐 语 名 跳出 


I 虽 “yy 3 Ge [ef 二 


全 部 中 断 ”重新 启动 ”显示 下 一 语句 。” 逐 过 程 ”在 源 中 显示 线程 
图 4.19 “调试 "工具 栏 


2.“ 调 试 "菜单 
“调试 "菜单 提供 了 更 完整 的 程序 错误 调试 命令 ,如 图 4. 20 所 示 。 
4.12.2 设置 断 点 本 mon Ian ma an 
程序 调试 的 基础 是 设置 断 点 , 断 点 是 在 程序 中 设置 的 ， 总 二 二 二 一 一 
一 个 位 置 (程序 行 ) ,程序 执行 到 该 位 置 时 中 断 (或 暂停 )。 | > Frewemo0p ant 
断 点 的 作用 是 在 调试 程序 中 , 当 程 序 执行 到 断 点 处 语句 时 。 恒 EREERGiaW ahrz 
会 暂停 程序 的 执行 , 供 程序 员 检查 这 一 位 置 上 程序 元 素 的 “aascipe9jo ， 
执行 情况 ,这 样 有 助 于 定位 产生 错误 输出 或 出 错 的 代 、 ”me ee 
码 段 。 9。 逐 汪 同 四 Fl 
设置 和 取消 断 点 的 方法 如 下 。 "ee 炙 
方法 1: 右 击 某 代码 行 ,从 出 现 的 快捷 菜单 中 选择 * 断 qi 
点 | 插入 断 点 "命令 (设置 断 点 ) 或 者 " 断 点 | 删除 断 点 "命令 
(取消 断 点 )。 导 d 攻 二 提示 0 .。 
方法 2: 将 光标 移 至 需要 设置 断 点 的 语句 处 ,然后 选 ee 
择 “ 调 试 ?菜单 中 的 “切换 断 点 "命令 或 按 F9 键 。 ph 


设置 了 断 点 的 代码 行 的 最 左 端 会 出 现 一 个 红色 的 圆 
点 ,并 且 该 代码 行 也 呈现 红色 背景 。 例 如 ,一 个 网 页 中 只 
有 一 个 Button 按钮 ,程序 中 包含 Button1_Click 事件 处 理 
过 程 , 图 4.21 显示 了 在 第 13 行 处 设 有 一 个 断 点 。 用 户 可 以 在 一 个 程序 中 设置 多 个 断 点 。 


图 4. 20 “调试 "菜单 


WebForm7.aspx 


$3 WebForm7 
1 using Systen; 


日 public partial class WebFormT : Systen. Web.UI.Page 
4 


2 

3 

4] 

5 日 protected void Page_Load(object sender, EventArgs e) 
6 

8 


9 有 日 protected void Buttonl_Click (object sender, EventAres e) 


11 int[] a = new int[10]; 


12 for (int i = 0; i < 20; i++) 
®@ 1 
14 了 


图 4.21 设置 一 个 断 点 


4.12.3 调试 过 程 

1. 开始 调试 过 程 

在 设置 断 点 后 ,从 “调试 ?菜单 中 选择 "启动 调试 "“ 逐 语句 ”或 * 逐 过 程 命 令 , 或 者 在 代码 
编辑 窗口 中 右 击 , 然 后 从 快捷 菜单 中 选择 “运行 到 光标 处 ”命令 , 即 开始 调试 过 程 。 

如 果 选 择 “ 启 动 调试 "命令 (或 按 F5 键 ), 则 应 用 程序 启动 并 一 直 执行 到 断 点 。 用 户 可 以 
在 任何 时 刻 中 断 执 行 以 检查 值 或 检查 程序 状态 。 

例如 ,在 设置 图 4. 21 中 的 断 点 后 ,选择 “调试 | 启动 调试 "命令 运行 该 网 页 , 单 击 Buttonl 
按钮 ,程序 执行 到 断 点 后 停 下 来 ,连续 单 击 》 六 9 , 当 a[ 门 超 界 时 出 现 如 图 4. 22 所 示 的 提示 ， 
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此 时 再 继续 运行 则 出 现 错误 。 
protected void Buttonl_Click(object sender, Eventhrgs e) 


int [] § = new int [10] ; 
for (int i = 0; i < 20; i+t) 
1] = 2*1; 
”局 用 户 代码 未 处 理 IndexOutOfRangeException 
索引 超出 了 数组 界限 . 


图 4.22 程序 执行 出 现 错误 


若 选 择 * 逐 语句 ”或 “ 逐 过 程 ?命令 ,程序 启动 并 执行 ,然后 在 过 程 的 第 一 行 中 断 。 
如 果 选 择 “ 执 行 到 光标 处 ”命令 , 则 应 用 程序 启动 并 一 直 执 行 到 断 点 或 光标 位 置 ,具体 看 是 
断 点 在 前 还 是 光标 在 前 。 用 户 可 以 在 源 窗 口中 设置 光标 位 置 。 在 某 些 情况 下 不 出 现 中 断 ,这 
意味 着 执行 始终 未 到 达 设 置 光标 处 的 代码 。 
2. 查看 调试 信息 
在 程序 调试 的 中 断 状态 下 可 以 通过 多 种 窗口 观察 变量 的 值 。 
Q@ 智能 感知 窗口 : 将 鼠标 放 在 希望 观察 的 执行 过 语句 的 变量 上 ,调试 器 会 通过 智能 感知 
窗口 自动 显示 执行 到 断 点 时 该 变量 的 值 , 甚 至 可 以 显示 执行 到 断 点 时 一 个 表达 式 的 值 。 
例如 ,在 图 4.22 所 示 的 情况 下 关闭 提示 框 ,将 鼠标 放 在 变量 i 上 ,看 到 的 结果 如 图 4. 23 
所 示 。 如 将 鼠标 放 在 a[ 门 上 ,再 展开 它 ,可 以 看 到 各 数组 元 素 的 值 ,如 图 4. 24 所 示 。 
protected void Buttonl_Click (object sender, EventArgs e) 
int[] a = new int[10]; 


for (int i = 0; i < 20; i++t) 
ali] = 2 * 


} 1@ il10 
图 4.23 显示 变量 i 的 值 


protected void Buttonl_Click (object sender, Eventhrgs e) 
{ 


int [] & = new int[10]; 
for (int i = i < 20; i++) 


cccicicroricicie 


品 吕 SmarNo 


图 4.24 显示 a 数组 元 素 的 值 


@ 即时 窗口 : 此 时 选择 “调试 | 窗口 | 即时 ”命令 ,出 现 即 时 窗口 ,可 以 输入 “? 变 量 或 表达 
式 ” 来 显示 变量 或 表达 式 的 值 ,如 图 4.25 所 示 。 

Q@ 局 部 变量 窗口 : 此 时 选择 “调试 | 窗口 | 局 部 变量 ”命令 ,出 现 局 部 变量 窗口 , 它 自动 显 
示 当 前 过 程 中 所 有 的 变量 值 ,如 图 4. 26 所 示 。 


protected void Buttonl_Click (object sender, EventAres e) 


int[] & = new int[10]: 
for (int i = 0; i < 20: i++) 


图 4.25 即时 窗口 中 显示 变量 i 的 值 


protected void Buttonl_Click (object sender, EventAres e) 


int[] a = new int[10]; 
for (i i < 20; i++) 


名 称 值 类 型 

画 @@ Sexception 【要 引 | 起 出 了 数 引 界限 . “System.Exception {SystemJndexOutOfRangeException} 
0 this {ASP.webform7_aspx} WebForm7 {ASP.webform]_aspx} 

田 加 sender {Tedt = "Button object {System.Web.ULWebControls.Button} 


Oe {System.EventArgs} System.EventArgs 


a 1 [i 


oa {intl10]} int] 


错误 列表 命令 窗口 局 部 变量 监视 1 


图 4.26 局 部 变量 窗口 显示 变量 ; 的 值 


@ 快速 监视 窗口 : 此 时 在 某 个 对 象 上 或 空白 处 右 击 , 从 弹出 的 快捷 菜单 中 选择 “快速 监 
视 " 命 令 , 出 现 快速 监视 窗口 , 它 用 于 显示 用 户 在 “表达 式 " 文 本 框 中 输入 的 表达 式 的 值 ,如 
图 4. 27 所 示 。 


protected void Buttonl_Click (object sender, EventArgs e) 
{ 
int [] a = new int[10] ; 
for (int i = 0; i ¢ 20 itt) 
BI = a* i 


名 称 什 
轩 =] | 数 得 家 引起 出 界限 lint 


[aa 


图 4.27 快速 监视 窗口 中 显示 变量 i 的 值 


在 程序 开始 调试 过 程 后 ,每 次 处 于 中 断 状态 时 ,用 户 通过 上 述 窗 口 观察 变量 或 表达 式 的 
值 ,然后 按 F5 键 继续 ,从 而 跟踪 变量 或 表达 式 的 变化 过 程 ,最 终 找 出 程序 出 错 的 原因 。 
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需要 注意 的 是 ,局 部 变量 窗口 和 快速 监视 窗口 不 同 于 即时 于 oo - . 
窗 体 , 它 具有 跟踪 变量 的 功能 , 当 按 F5 键 时 ,程序 继续 执行 ,此 | PP emet Explorer 


时 局 部 变量 窗口 和 快速 监视 窗口 的 变量 值 会 自动 发 生 相 应 的 改 | pe 
变 ,所 以 在 程序 调试 中 最 常用 的 是 这 两 个 窗口 。 : 
除了 上 述 调试 方式 外 ,用 户 还 可 以 使 用 工具 栏 中 的 Page esdina i masa a 
Inspector, 如 图 4. 28 所 示 。 单 击 Page Inspector 启动 它 进行 程 OWS- 
序 调试 ,这 里 不 再 介绍 。 图 4.28 选择 Page Inspector 


练习 题 4 


1. 简 述 C# 中 值 类 型 和 引用 类 型 的 异同 。 

2. 简 述 C# 中 值 类 型 变量 和 引用 类 型 变量 的 定义 方法 。 

3. 简 述 C# 中 结构 体 类 型 的 声明 和 使 用 方法 。 

4. 简 述 C# 中 switch 语句 的 执行 过 程 。 

5. 简 述 C# 中 while、do-while 和 for 语句 的 执行 过 程 。 

6. 简 述 C# 中 二 维 数组 的 定义 和 使 用 方法 。 

7. 简 述 C# 中 异常 处 理 语句 的 使 用 方法 。 

8. 简 述 C# 中 类 的 声明 方法 ,有 哪些 类 访问 修饰 符 和 类 成 员 访问 修饰 符 , 它 们 各 有 什么 
特点 。 

9. 简 述 C# 中 构造 函数 和 析 构 函数 的 特点 。 

10. 简 述 C# 中 类 的 静态 方法 和 非 静 态 方法 有 什么 不 同 。 

11. 简 述 C# 中 方法 参数 有 哪些 类 型 ,各 有 什么 特点 。 

12. 简 述 C# 中 方法 重 载 和 重 写 有 什么 不 同 。 

13， 简 述 出 现 调试 的 基本 过 程 。 


上 机 实验 题 4 


在 ch4 网 站 的 Classl. css 类 文件 中 添加 一 个 Class4 类 ,包含 link 和 sort 方法 ,前 者 用 于 
将 一 个 字符 串 数 组 的 所 有 元 素 连 接 成 一 个 字符 串 , 后 者 对 字符 串 数 组 中 的 所 有 元 素 递增 排序 。 
再 添加 一 个 名 称 为 Experment4. aspx 的 网 页 ,该 网 页 中 先 显示 一 组 字符 串 , 用 户 单 击 "排序 ” 
按钮 后 显示 排序 后 的 结果 ,如 图 4. 29 所 示 。 


I®) 大 http://localhost64480/cha/Experment4aspx Dr-ol ov 
碟 localhost x 


排序 前 : while if for break switch if-else do-while continue 


ED 


排序 后 : break continne do-while for if if-else switch while 


图 4.29 上 机 实验 题 4 网 页 的 运行 界面 


ASP.NET 的 常用 对 象 第 5 章 


ASP.NET 中 有 一 些 常用 的 内 置 对 象 , 当 Web 应 用 程序 运行 时 ,这 些 对 
象 提供 了 丰富 的 功能 ,例如 维护 Web 服务 器 活动 状态 、 网 页 输入 /输出 等 。 另 
外 ,通过 配置 Global. asax 文件 可 以 实现 Web 应 用 程序 和 会 话 的 初始 化 设 
置 等 。 

本 章 学 习 要 点 : 

回 理解 Web 应 用 程序 编程 的 难点 。 

回 掌握 Page 对 象 的 使 用 方法 。 

回 掌握 Response、Request、Server 对 象 的 使 用 方法 。 

掌握 Application、Session、Cookie 和 ViewState 对 象 的 使 用 方法 。 

回 掌 握 Global.asax 文件 的 配置 方法 。 

回 掌握 ASP.NET 网 页 的 执行 方式 和 ASP.NET 状态 管理 方法 。 

回 掌 握 ASP.NET 网 页 生命 周期 的 全 过 程 。 

回 灵 活 利 用 ASP.NET 对 象 设计 较 复 杂 的 网 页 。 


5.1 ASP.NET 对象 概 述 


5.1.1 Web 应 用 程序 编程 的 难点 及 其 应 对 


相对 传统 的 基于 客户 端的 应 用 程序 编程 ,Web 应 用 程序 编程 有 一 些 特殊 的 
难点 ,通常 包括 : 

。 实现 多 样式 的 Web 用 户 界面 : 使 用 基本 的 HTML 功能 来 设计 和 实现 
用 户 接口 既 困 难 又 费事 ,特别 是 在 网 页 具有 复杂 布局 且 包 含 大 量 动态 
内 容 和 功能 齐全 的 用 户 交互 对 象 时 。 

。 客户 端 与 服务 器 的 分 离 : 在 Web 应 用 程序 中 ,客户 端 (浏览 器 ) 和 服务 
器 是 不 同 的 程序 ,它们 通常 在 不 同 的 计算 机 (甚至 不 同 的 操作 系统 ) 上 
运行 ,因此 ,共同 组 成 应 用 程序 的 这 两 个 部 分 仅 共享 很 少 的 信息 ; 它们 
可 以 进行 通信 ,但 通常 只 交换 很 小 块 的 简单 信息 。 
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无 状态 执行 : 当 Web 服务 器 接收 到 对 某 个 网 页 的 请 求 时 会 找到 该 网 页 ,对 其 进行 处 
理 ,将 其 发 送 到 浏览 器 ,然后 丢弃 所 有 网 页 信息 。 如 果 用 户 再 次 请 求 同 一 网 页 ,服务 器 
则 会 重复 整个 过 程 ,从 头 开始 对 该 网 页 进行 重新 处 理 。 换 言 之 ,服务 器 不 会 记忆 它 已 
处 理 的 网 页 , 即 网 页 是 无 状态 的 。 因 此 ,如 果 应 用 程序 需要 维护 有 关 某 网 页 的 信息 ,其 
无 状态 的 性 质 就 成 为 了 一 个 问题 。 

未 知 的 客户 端 功 能 : 在 许多 情况 下 ,Web 应 用 程序 可 供 许 多 使 用 不 同 浏览 器 的 用 户 进 
行 访问 。 浏览 器 具有 不 同 的 功能 ,因此 很 难 创建 将 在 所 有 浏览 器 上 都 同样 正常 运行 的 
应 用 程序 。 

数据 访问 方面 的 复杂 性 : 对 位 于 传统 Web 应 用 程序 中 的 数据 源 进行 读 取 和 写 入 非常 
复杂 ,并 且 会 消耗 大 量 资 源 。 

可 缩放 性 方面 的 复杂 性 : 在 许多 情况 下 ,由 于 应 用 程序 的 不 同 组 件 之 间 缺 乏 兼容 性 ， 
导致 用 现 有 方法 设计 的 Web 应 用 程序 未 能 实现 可 伸缩 性 的 目标 。 对 于 开发 周期 较 短 
的 应 用 程序 ,这 往往 是 一 个 常见 的 导致 失败 的 方面 。 


为 了 处 理 这 些 难 点 ,ASP.NET 网 页 和 ASP.NET 网 页 框架 通过 以 下 几 个 方面 来 处 理 这 
些 难 题 。 


直观 ,一致 的 对 象 模 型 ASP.NET 网 页 框架 提供 了 一 种 对 象 模型 , 它 使 开发 人 员 能 够 
将 窗 体 当 作 一 个 整体 ,而 不 是 分 离 的 客户 端 和 服务 器 模块 。 在 此 模型 中 ,可 以 通过 比 
在 传统 Web 应 用 程序 中 更 为 直观 的 方式 对 网 页 进行 编程 ,其 中 包括 能 够 设置 网 页 元 
素 的 属性 和 响应 事件 。 此 外 ,ASP.NET 服务 器 控件 是 基于 HTML 网 页 的 物理 内 容 
以 及 浏览 器 与 服务 器 之 间 的 直接 交互 的 一 种 抽象 模型 。 通 常 可 以 按照 在 客户 端 应 用 
程序 中 使 用 控件 的 方式 使 用 服务 器 控件 ,而 不 必 考 虑 如 何 创建 HTML 来 显示 和 处 理 
控件 及 其 内 容 。 

事件 驱动 的 编程 模型 : ASP.NET 网 页 为 Web 应 用 程序 带 来 了 一 种 开发 人 员 熟 悉 的 
模型 ,该 模型 用 于 为 客户 端 或 服务 器 上 发 生 的 事件 编写 事件 处 理 程序 。ASP.NET 网 
页 框架 对 此 模型 进行 了 抽象 ,使 捕获 客户 端 上 的 事件 ,将 其 传输 到 服务 器 并 调用 适当 
方法 等 操作 的 基础 机 制 都 是 自动 的 ,并 对 于 开发 人 员 都 是 不 可 见 的 ,这 样 就 得 到 了 一 
个 清晰 的 .易于 编写 的 ,支持 事件 驱动 开发 的 代码 结构 。 

直观 的 状态 管理 : ASP.NET 网 页 框架 会 自动 处 理 网 页 及 其 控件 的 状态 维护 任务 , 它 
使 开发 人 员 能 够 以 显 式 方式 维护 应 用 程序 特定 信息 的 状态 。 这 种 状态 管理 无 须 使 用 
大 量 服务 器 资源 即 可 实现 ,而 且 可 以 通过 向 浏览 器 发 送 Cookie 来 实现 ,也 可 以 不 通过 
向 浏览 器 发 送 Cookie 来 实现 。 

独立 于 浏览 器 的 应 用 程序 : ASP.NET 网 页 框架 允许 开发 人 员 在 服务 器 上 创建 所 有 应 
用 程序 逻辑 ,而 无 须 针 对 浏览 器 之 间 的 差异 进行 显 式 编码 。 但 是 , 它 仍 允许 开发 人 员 
利用 浏览 器 特定 的 功能 ,方法 是 通过 编写 客户 端 代码 来 提供 增强 的 性 能 和 更 丰富 的 客 
户 端 体验 。 

.NET Framework 公共 语言 运行 库 支持 : ASP.NET 网 页 框架 是 在 .NET Framework 
的 基础 上 生成 的 ,因此 整个 框架 可 用 于 任何 ASP.NET 应 用 程序 。 开 发 人 员 的 应 用 程 
序 可 以 用 与 运行 库 兼 容 的 任何 语言 编写 。 此 外 ,数据 访问 通过 .NET Framework 提供 
的 数据 访问 基础 结构 (包括 ADO.NET) 得 到 了 简化 。 

.NET Framework 可 缩放 服务 器 性 能 : ASP.NET 网 页 框架 使 开发 人 员 能 够 将 Web 
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应 用 程序 从 一 台 只 装 有 一 个 处 理 器 的 计算 机 有 效 地 缩放 到 多 计算 机 “网 络 场 ,并且 无 
须 对 应 用 程序 的 逻辑 进行 复杂 的 更 改 。 


5.1.2 ASP.NET 的 内 置 对 象 


在 具体 解决 Web 应 用 程序 编程 的 难点 上 ,ASP.NET 提供 了 几 个 内 置 对 象 ,如 Response、 
Request 等 ,它们 是 ASP. NET 技术 中 最 重要 的 一 部 分 。 这 些 内 置 对 象 是 由 .NET Framework 
中 封装 好 的 类 来 实现 的 。 因 为 这 些 内 置 对 象 是 在 ASP.NET 网 页 初始 化 请 求 时 自动 创建 的 ， 
是 全 局 变量 ,不 需要 声明 就 可 以 直接 使 用 ,如 Response. Write(" Hello World" ) 就 是 直接 使 用 
了 Response 对 象 。 

ASP.NET 中 常用 的 内 置 对 象 及 其 说 明 如 表 5. 1 所 示 。 实 际 上 , Response、Request、 
Server、Application、Session 和 ViewState 都 是 Page 类 的 属性 。 


表 5.1 ASP.NET 中 常用 的 内 置 对 象 


对 象 名 说 明 

Page 用 于 操作 整个 网 页 

Response 用 于 向 浏览 器 输出 信息 

Request 提供 对 当前 网 页 请 求 的 访问 

Server 提供 服务 器 端的 一 些 属 性 和 方法 

Application 提供 对 所 有 会 话 的 应 用 程序 范围 的 方法 和 事件 的 访问 ,还 提供 对 可 用 于 存储 信 
息 的 应 用 程序 范围 的 缓存 的 访问 

Session 用 于 存储 特定 用 户 的 会 话 信 息 

Cookie 用 于 设置 或 获取 Cookie 信息 

ViewState 获取 状态 信息 的 字典 ,这 些 信息 开发 人 员 可 以 在 同一 网 页 的 多 个 请 求 间 保存 和 
还 原 服务 器 控件 的 视图 状态 


5.2 Page 对 象 


Page 类 是 一 个 用 作 Web 应 用 程序 的 用 户 界 面 的 类 ,Page 对 象 其 实 就 是 C# 中 Web 应 用 
程序 的 . aspx 文件 .又 称 为 网 页 。Page 对 象 是 网 页 中 所 有 服务 器 控件 的 容器 。 也 就 是 说 ,每 一 
个 ASP.NET 网 页 都 是 一 个 Page 对 象 ,Page 对 象 是 由 System. Web. UI 命名 空间 中 的 Page 
类 来 实现 的 ,Page 类 与 扩展 名 为 . aspx 的 文件 相关 联 , 这 些 文件 在 运行 时 被 编译 为 Page 对 象 ， 
并 缓存 在 服务 器 内 存 中 。 

由 于 网 页 编译 后 所 创建 的 类 由 Page 派生 而 来 ,因此 网 页 可 以 直接 使 用 Page 对 象 的 属性 
(包括 各 种 ASP.NET 的 内 置 对 象 ) .方法 和 事件 。 


5.2.1 Page 对 象 的 属性 


Page 对 象 的 常用 属性 及 其 说 明 如 表 5. 2 所 示 , 除 此 之 外 ,Page 对 象 还 包括 Response、 
Request Server .Session 和 Application 对 象 属性 ,下 面 介 绍 其 中 两 个 属性 的 用 法 。 

1. lsPostBack 属性 

该 属性 是 一 个 布尔 值 ,由 系统 自动 设置 其 值 , 当 为 True 时 表示 当前 网 页 是 为 响应 客户 端 回 
传 (PostBack, 指 网 页 及 操作 状态 传 回 服务 器 ) 而 加 载 ,为 False 时 表示 首次 加 载 和 访问 网 页 。 
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属 性 


表 5.2 Page 对 象 的 常用 属性 及 其 说 明 
说 明 


ClientQueryString ”获取 请 求 的 URL 的 查询 字符 串 部 分 


ErrorPage 
Form 
JsAsync 
JsPostBack 


JsValid 
Master 


MasterPageFile 


获取 或 设置 错误 页 ,在 发 生 未 处 理 的 页 异常 的 事件 时 请 求 浏览 器 将 被 重 定向 到 该 页 
获取 网 页 的 HTML 表单 

获取 一 个 值 , 该 值 指示 是 否 异 步 处 理 网 页 

获取 一 个 值 , 该 值 指示 该 页 是 否 正 为 响应 客户 端 回 传 而 加 载 ,或 者 它 是 否 正 被 首次 加 
载 和 访问 

获取 一 个 值 ,该 值 指示 页 验证 是 否 成 功 

获取 确定 页 的 整体 外 观 的 母 版 页 

获取 或 设置 母 版 页 的 文件 名 


在 ASP.NET 网 页 的 处 理 过 程 中 ,IsPostBack 属性 值 的 设置 如 下 : 

Q@ 用 户 通过 客户 端 浏 览 器 请 求 网 页 ,网 页 第 一 次 运行 。 

@ Web 服务 器 接受 请 求 , 将 其 代码 发 给 ASP.NET 引擎 ,此 时 IsPostBack 属性 为 False， 
ASP.NET 引擎 执行 服务 器 脚本 代码 ,产生 HTML 文件 , 交 给 Web 服务 器 , Web 服务 器 将 其 


发 送 到 客户 端 。 


@ 客户 端 用 户 看 到 显示 的 页 面 ,输入 信息 或 从 可 选项 中 进行 选择 ,或 者 单 击 按钮 。 

@ 此 时 网 页 又 发 送 到 Web 服务 器 (第 2 次 或 以 后 运行 网 页 ), Web 服务 器 接受 请 求 并 将 
其 代码 发 给 ASP.NET 引擎 ,在 ASP.NET 中 称 此 为 “ 回 发 ”或 “ 回 传 ”, 这 时 IsPostBack 属性 
为 True, ASP. NET 引擎 执行 服务 器 脚本 代码 ,产生 HTML 文件 , 交 给 Web 服务 器 , Web 服 
务 器 将 其 发 送 到 客户 端 。 

以 上 过 程 循环 执行 ,直到 用 户 退出 。 

2. IsValid 属性 

该 属性 用 于 获取 一 个 布尔 值 ,指示 网 页 上 的 验证 控件 是 否 验 证 成 功 。 若 网 页 验证 控件 全 
部 验证 成 功 ,该 值 为 True', 和 否则 为 False。 

IsValid 属性 在 网 页 验证 中 起 着 重要 作用 。 例 如 ,以 下 事件 过 程 通过 mylabel 标签 输出 验 


证 结果 : 


void Button1_Click(Object Sender, EventArgs E) 
{ if (Page. IsValid) // 也 可 写成 if (Page. IsValid == True) 
mylabel. Text = "信息 验证 成 功 !"; 


else 


mylabel. Text = "信息 验证 失败 "; 


} 


5.2.2 Page 对 象 的 方法 
Page 对 象 的 常用 方法 及 其 说 明 如 表 5. 3 所 示 。 
5.2.3 ”Page 对 象 的 事件 
Page 的 常用 事件 及 其 说 明 如 表 5.4 所 示 , 下 面 对 主 要 的 事件 做 进一步 的 介绍 。 


1. Init 事件 


Init 事件 对 应 的 事件 处 理 过 程 为 Page_Init, 在 初始 化 网 页 时 触发 该 事件 。Init 事件 只 触 
发 一 次 。Init 事件 通常 用 来 完成 系统 所 需 的 初始 化 ,如 设置 网 页 .控件 属性 的 初始 值 。 
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表 5.3 Page 对 象 的 常用 方法 及 其 说 明 


方 ”法 说 明 
DataBind 将 数据 源 绑 定 到 被 调用 的 服务 器 控件 及 其 所 有 子 控件 
Eval 计算 数据 绑 定 表达 式 
FindControl 在 网 页 中 搜索 指定 的 服务 器 控件 
RegisterClientScriptBlock ”向 网 页 发 出 客户 端 脚本 块 
MapPath 检索 虚拟 路 径 ( 绝 对 的 或 相对 的 ) 或 应 用 程序 相关 的 路 径 映 射 到 的 物理 路 径 
Validate 指示 网 页 中 的 所 有 验证 控件 进行 验证 


表 5.4 Page 对 象 的 常用 事件 及 其 说 明 


事 件 说 明 
Prelnit 在 网 页 初始 化 开始 时 引发 
Init 当 服 务 器 控件 初始 化 时 引发 
InitComplete 在 网 页 初始 化 完成 时 引发 
PreLoad 在 网 页 Load 事件 之 前 引发 
Load 当 服 务 器 控件 加 载 到 Page 对 象 中 时 引发 
LoadComplete 在 网 页 生命 周期 的 加 载 阶段 结束 时 引发 
PreRender 在 加 载 Control 对 象 之 后 .呈现 之 前 引发 


PreRenderComplete 在 呈现 网 页 内 容 之 前 引发 
SaveStateComplete 在 网 页 已 完成 对 页 和 页 上 控件 的 所 有 视图 状态 和 控件 状态 信息 的 保存 后 引发 
Unload 当 服务 器 控件 从 内 存 中 印 载 时 引发 


2. Load 事件 

Load 事件 对 应 的 事件 处 理 过 程 为 Page_Load。 当 在 内 存 中 加 载 网 页 时 触发 该 事件 ,在 网 
页 每 次 加 载 时 都 触发 ,不 管 是 首次 加 载 ,还 是 按 用 户 要 求 回 送信 息 再 次 调用 网 页 的 回 传 加 载 ， 
Page_Load 事件 处 理 过 程 都 会 被 执行 。 

如 果 仅 希望 在 网 页 第 一 次 加 载 时 执行 Page_Load 事件 处 理 过 程 ,可 以 使 用 Page. 
IsPostBack 属性 。 如 果 Page. IsPostBack 属性 为 False, 则 网 页 第 一 次 被 载 入 ,如 果 为 True, 则 
网 页 传 回 服务 器 。 例 如 ,在 以 下 Page_Load 事件 处 理 过 程 中 ,通过 Page. IsPostBack 属性 可 以 
实现 首次 加 载 和 回 传 时 执行 不 同 的 程序 代码 : 


void Page_Load(Object 0, EventArgs e) 
{ if (!Page.IsPostBack) // 也 可 写成 if (Page. IsPostBack == False) 
{ // 如 果 网 页 为 首次 加 载 , 则 进行 一 些 操 作 


} 


else 


{ // 如 果 网 页 为 回 传 , 则 进行 一 些 操作 


i 
} 
3. Unload 事件 
Unload 事件 对 应 的 事件 处 理 过 程 为 Page_Unload, 当 网 页 从 内 存 中 务 载 并 将 输出 结果 发 
送 给 浏览 器 时 触发 该 事件 。Unload 事件 主要 用 来 执行 最 后 的 资源 清理 工作 ,如 关闭 文件 . 关 
闭 数 据 库 连接 和 释放 对 象 等 。 由 于 这 个 事件 是 最 后 事件 ,网 页 的 所 有 内 容 已 经 传 到 客户 端 浏 
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览 器 ,所 以 不 能 使 用 它 来 改变 控件 。 这 个 事件 并 不 是 指 用 户 在 浏览 器 端 关闭 网 页 ,而 是 从 IIS 
角度 讲 , 网 页 从 内 存 中 务 载 时 发 生 这 个 事件 。 


5.2.4 Page 对 象 的 应 用 


本 节 通 过 一 个 示例 说 明 Page 对 象 的 应 用 。 

【 例 5.1】 在 D 盘 ASP.NET 目录 中 建立 一 个 ch5 的 子 目录 ,将 其 作为 网 站 目录 ,然后 创 
建 一 个 WebForml. aspx 网 页 ,其 功能 是 说 明 Page 对 象 的 IsPostBack 属性 的 应 用 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012 。 

@ 选择 "文件 | 新 建 | 网 站 ”命令 ,出 现 * 新 建 网 站 ”对话 框 ,选择 "ASP.NET 空 网 站 ”模板 ， 
选择 “Web 位 置 ”为 “文件 系统 ”, 单 击 “ 浏 览 ” 按 钮 ,然后 选择 “D;\ASP.NET\ch5" 目 录 , 单 击 
“确定 ”按钮 ,这 样 就 创建 了 一 个 空 的 网 站 ch5。 

@ 选择 “网 站 | 添加 新 项 命令, 出现“ 添加 新 项 -ch5” 对 话 框 ,在 中 间 列 表 中 选择 "Web 窗 
体 页 ”, 将 文件 名 称 改 为 WebForml. aspx, 其 他 保持 默认 项 , 单 击 * 添 加 ”按钮 。 

@ 进入 设计 视图 ,设计 该 网 页 界面 如 图 5. 1 所 示 , 其 中 包含 一 个 文本 框 TextBoxl .一 个 
按钮 Buttonl 和 一 个 标签 Labell。 在 该 网 页 上 设计 如 下 事件 过 程 : 

protected void Page_Load( object sender, EventArgs e) 

{ if (Page. IsPostBack ==true) 

Labell Text = TtBaxl Text +": 您 好 ,已 经 提交 了 1"; 
else | 姓名 : | 
Labell. Text =“" 您 还 没有 提交 !"; EE 


} 

@ 单 击 工具 栏 中 的 > Imternet Explorer 按钮 运行 本 网 页 ， 
初始 运行 界面 如 图 5. 2 所 示 。 此 时 Page. IsPostBack 返回 上 1 ” 
False, 在 文本 框 中 输入 * 王 华 ”, 单 击 * 提 交 "按钮 ,其 运行 界 | 对 | se 时 
面 如 图 5. 3 所 示 , 这 是 因为 此 时 网 页 是 回 传 状态 ,所 以 ”图 5.1 WebForml 网 页 设计 界面 
Page. IsPostBack 返回 True。 


Label _ | 


全 | 愿 hapy/localhost5307: P - © 
@ localhost x 


姓名 : 


[ 问 ] 


您 还 没有 提交 ! 


图 5.2 WebForml 网 页 运行 界面 一 5.3 WebForml 网 页 运行 界面 二 


5.3 ”Response 对 象 


Response 对 象 实际 上 是 与 该 Page 对 象 关联 的 HttpResponse 对 象 , 用 于 控制 服务 器 发 送 
给 浏览 器 的 信息 ,包括 直接 发 送信 息 给 浏览 器 、 重 定向 浏览 器 到 另 一 个 URL 或 设置 cookie 的 
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值 ,特别 是 可 以 使 用 Response 对 象 高 效 地 实现 在 不 同 页 面 的 转换 。 
5.3.1 Response 对 象 的 属性 


Response 对 象 的 常用 属性 及 其 说 明 如 表 5.5 所 示 。 
表 5.5 Response 对 象 的 常用 属性 及 其 说 明 


属 性 说 明 
Buffer 获取 或 设置 一 个 值 ,该 值 指示 是 否 缓冲 输出 ,并 在 完成 处 理 整个 响应 之 后 将 其 发 送 
BufferOutput 获取 或 设置 一 个 值 ,该 值 指示 是 否 缓冲 输出 ,并 在 完成 处 理 整 个 页 之 后 将 其 发 送 
Cache 获取 网 页 的 缓存 策略 (过 期 时 间 .保密 性 .变化 子 句 ) 
Cookies 获取 响应 Cookie 集合 
Expires 获取 或 设置 在 浏览 器 上 缓存 的 页 过 期 之 前 的 分 钟 数 。 如 果 用 户 在 网 页 过 期 之 前 返 


回 该 页 , 则 显示 缓存 版 本 。 提 供 Expires 是 为 了 与 以 前 版 本 的 ASP 兼容 
IsClientConnected ”获取 一 个 值 ,通过 该 值 指示 客户 端 是 否 仍 连接 在 服务 器 上 


5.3.2 Response 对 象 的 方法 
Response 对 象 的 常用 方法 及 其 说 明 如 表 5.6 所 示 , 下 面 介绍 几 个 主要 方法 的 用 法 。 
表 5.6 Response 对象 的 常用 属性 及 其 说 明 
许 法 说 明 
Output 启用 到 输出 HTTP 响应 流 的 文本 输出 
OutputStream 启用 到 输出 HTTP 内 容 主体 的 二 进 制 输出 
RedirectLocation ”获取 或 设置 HTTP* 位 置 " 标 头 的 值 
Status 设置 返回 到 客户 端的 Status 栏 
AppendCookie 将 一 个 HTTP Cookie 添加 到 内 部 Cookie 集合 
AppendToLog 将 自 定义 日 志 信息 添加 到 lnternet 信息 服务 (IIS) 日 志文 件 
BinaryWrite 将 一 个 二 进 制 字符 串 写 入 HTTP 输出 流 
Clear 清除 缓冲 区 流 中 的 所 有 内 容 输出 
ClearContent 清除 缓冲 区 流 中 的 所 有 内 容 输出 
ClearHeaders 清除 缓冲 区 流 中 的 所 有 头 


Close 关闭 到 客户 端的 套 接 字 连 接 
End 将 当前 所 有 缓冲 的 输出 发 送 到 客户 端 ,停止 该 网 页 的 执行 ,并 引发 EndRequest 事件 
Redirect 将 客户 端 重 定向 到 新 的 URL 
Write 将 信息 写 和 人 HTTP 响应 输出 流 
WriteFile 将 指定 的 文件 直接 写 人 HTTP 响应 输出 流 
1. Write 方法 


Write 方法 可 以 将 一 个 字符 串 写 入 HTTP 响应 输出 流 。 例 如 : 
Response. Write( "现在 时 间 为 : ”+ DateTime. Now. ToString()); 
用 于 输出 当前 的 时 间 。 
实际 上 Write 方法 将 指定 的 字符 串 输 出 到 客户 端 ,由 客户 端 浏览 器 解释 后 输出 ,所 以 这 个 
输出 字符 串 中 可 以 包含 一 些 HTML 格式 输出 标记 。 
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2. End 方法 

End 方法 用 来 输出 当前 缓冲 区 的 内 容 , 并 中 止 当前 网 页 的 处 理 。 例 如 

Response. Write( "欢迎 光临 "); 

Response. End( ); 

Response. Write( "我 的 网 站 !"); 

只 输出 “欢迎 光临 ”而 不 会 输出 “我 的 网 站 !”。End 方法 常用 来 帮助 调试 程序 。 

3. Redirect 方法 

使 用 Redirect 方法 可 以 实现 在 不 同 网 页 之 间 进 行 跳 转 的 功能 ,也 就 是 可 以 从 一 个 网 页 地 
址 转 到 另 一 个 网 页 地 址 ,可 以 是 本 机 的 网 页 ,也 可 以 是 远程 的 网 页 地 址 。 其 基本 使 用 格式 
如 下 : 


Redirect(ur1) 


其 中 ,url 指定 目标 的 位 置 。 例 如 ,执行 以 下 代码 显示 武汉 大 学 的 主页 : 
Response. Redirect( "http://www. whu. edu. cn/"); 


另 一 种 使 用 格式 如 下 : 
Redirect(url, endResponse) 


其 中 ,endResponse 为 bool 值 ,指示 当前 网 页 的 执行 是 否 应 终止 。 例 如 ,以 下 服务 器 端 代 
码 使 用 IsClientConnected 属性 来 检查 请 求 网 页 的 客户 端 是 否 仍 与 服务 器 连接 。 如 果 
IsClientConnected 为 true, 则 调用 Redirect 方法 ,因此 客户 端 可 以 查看 另 一 网 页 ; 如 果 
IsClientConnected 为 false, 将 调用 End 方法 ,并 且 所 有 网 页 处 理 都 将 终止 : 

if (Response. IsClientConnected) 

{  // 如 果 是 连接 的 , 则 转向 另 一 个 网 页 并 不 终止 当前 网 页 

Response. Redirect("anotherpage.aspx", false); 
} 


else 

{  // 如 果 浏 览 器 不 是 连接 的 ,停止 使 用 的 响应 处 理 
Response. End( ); 

} 


注意 : Redirect 执行 客户 端 重 定 向 时 ,浏览 器 请 求 新 资源 。 此 重 定向 是 一 个 进入 系统 的 
新 请 求 , 因 此 需要 接受 IIS 和 ASP.NET 安全 策略 的 所 有 身份 验证 和 授权 逻辑 的 检验 。 


5.3.3 ”Response 对 象 的 应 用 


本 节 通 过 一 个 示例 说 明 Response 对 象 的 应 用 。 

【 例 5.2】 在 ch5 网 站 中 设计 一 个 WebForm2. aspx 网 页 ,其 功能 是 使 用 Response 对 象 
的 Write 方法 输出 若干 文字 。 

解 : 其 步骤 如 下 。 

@ 打开 ch5 网 站 ,选择 网 站 | 添加 新 项 "命令, 出现“ 添加 新 项 -ch5” 对 话 框 ,在 中 间 列 表 中 
选择 “Web 窗 体 ”, 将 文件 名 称 改 为 WebForm2. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 。 

@ 该 网 页 的 设计 界面 中 不 包含 任何 内 容 。 进 入 设计 视图 ,在 空白 处 右 击 , 在 出 现 的 快捷 
菜单 中 选择 “查看 代码 ”命令 ,进入 代码 编辑 窗口 ,设计 如 下 事件 过 程 : 

protected void Page_Load(object sender, EventArgs e) 

{ Response. Write(" 现 在 时 间 为 : ”+ DateTime. Now. ToString()+"<br>"); 
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Response. Write("<hl > 中 华人 民 共 和 国 </hl >"); 
Response. Write("<h2 > 中 华人 民 共 和 国 </h2 >"); 
Response. Write("<h3 > 中华 人民 共 和 国 </h3 >"); 


} 


@ 单 击 工具 栏 中 的 Pp Internet Explorer 按钮 运行 本 网 页 ,其 运行 界面 如 图 5.4 所 示 。 


5.4 Request 对 象 


pyfocalhost5307 ~ ©] 人 
x 


现在 时 间 为 ，2015/4/13 14.54 25 


中 华人 民 共 和 国 


中 华人 民 共 和 国 
中 华人 民 共 和 国 


图 5.4 WebForm2 网 页 运行 界面 


Request 对 象 实际 上 是 请 求 的 页 的 HttpRequest 对 象 ,其 主要 功能 是 从 客户 端 获 取 数 据 。 
使 用 该 对 象 可 以 访问 任何 HTTP 请 求 传递 的 信息 ,包括 使 用 post 方法 或 者 get 方法 传递 的 参 
数 .cookie 和 用 户 验证 。 也 就 是 说 ,Request 对 象 使 ASP.NET 能 够 读 取 客 户 端 在 Web 请 求 期 


间 发 送 的 HTTP 值 。 


5.4.1 Request 对 象 的 属性 
Request 对 象 的 常用 属性 及 其 说 明 如 表 5.7 所 示 。 


表 5.7 ”Request 对 象 的 常用 属性 及 其 说 明 


属 性 说 明 
ApplicationPath 获取 ASP.NET 应 用 的 虚拟 目录 (URL) 
PhysicalPath 获得 ASP.NET 应 用 的 物理 目录 
Browser 获取 有 关 正 在 请 求 客户 的 客户 端的 浏览 器 功能 的 信息 
Cookies 获取 在 请 求 中 发 送 的 Cookies 集 
FilePath 获取 当前 请 求 的 虚拟 路 径 
Form 获取 回 传 到 网 页 的 窗 体 变量 集 
Headers 获取 HTTP 头 部 
ServerVariables 获取 服务 器 变量 的 名 字 / 值 集 
QueryString 获取 HTTP 查询 字符 串 变 量 集合 
Url 获取 有 关 当 前 请 求 的 URL 的 信息 
UserHostAddress 获取 远程 客户 端 主机 的 地 址 
UserHostName 获取 远程 客户 端的 DNS 名 称 


5.4.2 ”Request 对 象 的 方法 
Request 对 象 的 常用 方法 及 其 说 明 如 表 5. 8 所 示 , 下 面 介绍 几 个 主要 方法 的 用 法 。 
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表 5.8 Request 对 象 的 常用 方法 及 其 说 明 


方 ” 法 说 明 
MapPath 返回 URL 的 物理 路 径 
SaveAs 将 HTTP 请 求 保存 到 文件 中 
ValidateInput 对 通过 Cookies .Form 和 QueryString 属性 访问 的 集合 进行 验证 


1. MapPath 方法 

其 使 用 语法 格式 如 下 : 

MapPath( VirtualPath) 

该 方法 将 当前 请 求 的 URL 中 的 虚拟 路 径 VirtualPath 映射 到 服务 器 上 的 物理 路 径 。 参 
数 VirtualPath 用 于 指定 当前 请 求 的 虚拟 路 径 ( 可 以 是 绝对 路 径 ,也 可 以 是 相对 路 径 ) ,返回 值 
为 与 VirtualPath 对 应 的 服务 器 端 物 理 路 径 。 

例如 ,以 下 语句 : 


Response. Write(Request. MapPath( "aa" ) ); 


在 浏览 器 中 输出 aa 所 在 的 物理 路 径 。 

2. SaveAs 方法 

其 使 用 语法 格式 如 下 : 

SaveAs(filename, includeHeaders) 

该 方法 将 客户 端的 HTTP 请 求 保存 到 磁盘 。 参 数 filename 用 于 指定 文件 在 服务 器 上 保 
存 的 位 置 ; 布尔 型 参数 includeHearders 用 于 指定 是 否 同时 保存 HTTP 头 。 

例如 ， 


Request. SaveAs("H:\aaa", True); 


则 执行 后 在 HH 盘 根 目 录 产 生 aaa 文件 。 
5.4.3 ” Request 对 象 的 应 用 


对 于 网 页 中 的 form 元 素 ,method 属性 取 值 为 get” 表示 从 服务 器 上 获取 数据 , 取 值 为 
“post” 表 示 向 服务 器 传送 数据 。 

get 是 把 参数 数据 队列 加 到 提交 表单 的 action 属性 所 指 的 URL 中 , 值 和 表单 内 的 各 个 字 
段 一 一 对 应 ,在 URL 中 可 以 看 到 。 对 于 get 方式 ,服务 器 端 用 Request. QueryString 获取 变 
量 的 值 。 

post 是 通过 HTTP 的 post 机 制 将 表单 内 的 各 个 字段 与 其 内 容 放置 在 HTML HEADER 
内 一 起 传送 到 action 属性 所 指 的 URL 地 址 ,用 户 看 不 到 这 个 过 程 。 对 于 post 方式 ,服务 器 端 
用 Request. Form 获取 提交 的 数据 。 

通常 ,get 传送 的 数据 量 较 小 ,post 传送 的 数据 量 较 大 ; get 的 安全 性 非常 低 ,post 的 安全 
性 较 高 ,但 是 get 的 执行 效率 比 post 高 。 

1. 获取 客户 端 机 器 和 浏览 器 的 相关 信息 

通常 使 用 Request 对 象 的 Browser、Url、Path 和 PhysicalPath 等 属性 获取 客户 端 机 器 和 
浏览 器 的 相关 信息 。 

【 例 5.3】 在 ch5 网 站 中 设计 一 个 WebForm3. aspx 网 页 ,其 功能 是 使 用 Response 对 象 
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的 Write 方法 输出 若干 文字 。 

解 : 其 步骤 如 下 。 

@ 打开 ch5 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch5” 对 话 框 , 在 中 间 列 表 中 
选择 “Web 窗 体 ”, 将 文件 名 称 改 为 WebForm3. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 。 

@ 其 设计 界面 中 不 包含 任何 内 容 。 进 入 设计 视图 ,在 空白 处 右 击 , 在 出 现 的 快捷 菜单 中 
选择 “查看 代码 ”命令 ,进入 代码 编辑 窗口 ,设计 如 下 事件 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
{ ”Response. Write(" 浏 览 器 名 称 和 主 版 本 号 :" 
+ Request. Browser. Type + "< br >"); 

Response. Write(" 浏 览 器 名 称 : " + Request. Browser. Browser + "< br >"); 
Response. Write(" 浏 览 器 平台 : "+ Request. Browser. Platform+ "<br>"); 
Response. Write(" 客 户 端 IP 地址: " + Request. UserHostAddress + "< br >"); 
Response. Write(" 当 前 请 求 的 URL: " + Request. Url + "< br >"); 
Response. Write(" 当 前 请 求 的 虚拟 路 径 : " + Request. Path+ "<br>"); 
Response. Write( "当前 请 求 的 物理 路 径 : " + Request. PhysicalPath+ "<br>"); 


@ 单 击 工具 栏 中 的 p> Inmternet Explorer 按钮 运行 本 网 页 ,其 运行 界面 如 图 5. 5 所 示 。 


http:/localhost:53072/WebForm3.aspx 
水 /WebForm3 aspx 
当前 请 求 的 物理 跨 径 ，D: -ASPNEThSVWebFonm3， aspx 


图 5.5 WebForm3 网 页 运行 界面 


2. 使 用 Request 对 象 的 QuerySiring 属性 在 网 页 之 间 传 递 数据 

在 上 网 的 过 程 中 ,用 户 经 常 发 现 网 址 后 面 跟 一 串 字 符 , 这 就 是 通过 URL 后 面 的 字符 串 在 
两 个 网 页 之 间 传 递 参 数 , 它 是 基于 get 方式 的 。 网 页 的 QueryString 属性 保存 这 些 参数 和 值 ， 
因此 可 以 通过 Request 的 QueryString 在 网 页 之 间 传 递 信息 。 

【 例 5.4】 在 ch5 网 站 中 设计 WebForm4 和 WebForm4-1 两 个 网 页 ,其 功能 是 说 明 
QueryString 属性 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch5 网 站 ,添加 一 个 网 页 WebForm4. aspx。 

@ 其 设计 界面 如 图 5.6 所 示 , 包 含有 两 个 文本 框 (ID 分 别 为 uname 和 uage) 和 一 个 命令 
按钮 Button1 。 进 入 源 视 图 ,将 二 form> 元 素 改 为 ， 

<form id = "forml”runat = "server" method= "get" action = "WebForm4 — 1.aspx"> 

在 该 网 页 中 不 设计 Button1_Click 事件 过 程 ,Buttonl 命令 按钮 仅仅 起 到 提交 网 页 的 
作用 。 

@ 再 添加 一 个 网 页 WebForm4-1. aspx, 其 设计 界面 如 图 5.7 所 示 , 包 含有 一 个 标签 
Labell。 在 该 网 页 上 设计 如 下 事件 过 程 : 
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protected void Page_ Load( object sender, EventArgs e) 
和 string uname, uage; 
uname = Request. QueryString[ "uname"]; 
uage = Request. QueryString[ "uage"]; 
Labell. Text = uname +": 您 好 ! 您 的 年 龄 为 ”+ uage +" 岁 "; 


[E772 FE 
Label 
4 » | 4 mw = a i » 
5 设计 | 折 分 |。 源 | [|][<formsforml>| <dv> 站 na 设计 |9 拆 分 |。 源 | |4] <dv> | 
图 5.6 WebForm4 网 页 设计 界面 图 5.7 WebForm4-1 网 页 设计 界面 


@ 单 击 工具 栏 中 的 PP Interet Explorer 按钮 运行 WebForm4 网 页 ,输入 姓名 为 “ 王 华 ”年 龄 
为 "26”, 如 图 5. 8 所 示 , 然 后 单 击 “ 单 击 ” 按 钮 ,出 现 如 图 5. 9 所 示 的 界面 ,可 以 看 到 其 URL 地 
址 为 *http://localhost:53072/WebForm4-1. aspx? _VIEWSTATE= "后跟 一 串 乱 码 , 这 些 
乱码 是 表单 中 uname 和 uage 的 加 密 数 据 。WebForm4-1 网 页 的 Page_Load 事件 过 程 从 中 提 
取 QueryString 属性 中 对 应 变量 的 值 并 输出 。 


"x 
OB pecattostss07. p - © 
感 localhost x x 
get 方式 传递 数据 Bet 传 递 的 信息 如 下 : 
姓名 : [到 | 王 华 :您 好 ! 您 的 年 龄 为 26 岁 
年 零 : [26| * 
图 5.8 WebForm4 网 页 运行 界面 图 5.9 WebForm4-1 网 页 运行 界面 


3. 使 用 Request 对 象 的 Form 属性 在 网 页 之 间 传 递 数 据 

使 用 Request 的 Form 属性 可 以 获取 客户 端 通过 post 方式 传递 的 表单 数据 ,从 而 实现 网 
页 之 间 的 数据 传递 。 

【 例 5.5】 在 ch5 网 站 中 设计 WebForm5 和 WebForm5-1 两 个 网 页 ,其 功能 是 说 明 Form 
属性 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch5 网 站 ,添加 一 个 网 页 WebForm5. aspx。 

@ 其 设计 界面 与 WebForm4 相似 ,包含 有 两 个 文本 框 (ID 分 别 为 uname 和 uage) 和 一 个 
命令 按钮 Button1。 进 入 源 视 图 ,将 二 form 放 元 素 改 为 : 


<form id = "forml" runat = "server" method= "post" action= "WebForm5 - 1.aspx"> 
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在 该 网 页 中 不 设计 Button1_Click 事件 过 程 , Buttonl 命令 按钮 仅仅 起 到 提交 网 页 的 
作用 


@ 再 添加 一 个 网 页 WebForm5-1. aspx, 其 设计 界面 与 WebForm4-1 相似 ,包含 有 一 个 标 
签 Labell 。 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
{ string uname, uage; 
uname = Request. Form["uname"]; 
uage = Request.Form[ "uage" ]; 
Labell. Text = uname +": 您 好 ! 您 的 年 龄 为 ”+ uage + " 岁 "; 
} 
@ 单 击 工具 栏 中 的 PP Interet Explorer 按钮 运行 WebForm5 网 页 ,输入 姓名 为 “ 王 华 ”、 年 龄 
为 *26”, 类 似 图 5. 8 所 示 , 然 后 单 击 “ 单 击 ” 按 钮 ,出 现 类 似 图 5.9 所 示 的 界面 ,WebForm5-1 网 
页 的 Page_Load 事件 过 程 提取 Form 属性 中 对 应 变量 的 值 并 输出 ,同时 看 到 其 URL 地 址 为 
“http://localhost:53072/WebForm5-1. aspx”, 没 有 看 到 例 5. 4 那样 的 乱码 ,这 就 是 post 和 
get 方式 的 区 别 。 


5.5 Server 对 象 

Server 对 象 实际 上 是 HttpServerUtility 类 的 实例 ,提供 对 服务 器 的 方法 和 属性 的 访问 ， 
可 以 获取 服务 器 的 信息 ,对 HTML 文本 进行 编码 和 解码 等 ,如 文件 的 物理 路 径 等 。 
5.5.1 Server 对 象 的 属性 


Server 对 象 的 常用 属性 及 其 说 明 如 表 5.9 所 示 。 
表 5.9 Server 对 象 的 常用 属性 及 其 说 明 


属 性 说 明 
MachineName 作用 是 获取 服务 器 的 名 称 
ScriptTimeOnut 获取 和 设置 请 求 超时 值 (以 秒 计 ) 


5.5.2 Server 对 象 的 方法 
Server 对 象 的 常用 方法 及 其 说 明 如 表 5. 10 所 示 , 下 面 介 绍 几 个 主要 方法 的 用 法 。 
表 5.10 Server 对 象 的 常用 方法 及 其 说 明 


浪 法 说 明 

Execute 使 用 另 一 页 执行 当前 请 求 

HtmlEncode 对 要 在 浏览 器 中 显示 的 字符 串 进 行 编码 

HtmlDecode 对 字符 串 进行 URL 解码 并 返回 已 解码 的 字符 串 

UrlEncode 对 指定 字符 串 以 URL 格式 进行 编码 

UrlPathEncode 对 URL 字符 串 的 路 径 部 分 进行 URL 编码 并 返回 编码 后 的 字符 串 
MapPath 返回 与 Web 服务 器 上 的 指定 虚拟 路 径 相对 应 的 物理 文件 路 径 


Transfer 终止 当前 网 页 的 执行 ,并 开始 执行 新 的 请 求 网 页 
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1. MapPath 方法 
使 用 MapPath 方法 可 以 获得 服务 器 文件 的 物理 路 径 。 其 使 用 语法 格式 如 下 : 


Server. MapPath( path); 


其 中 ,path 指定 Web 服务 器 的 虚拟 路 径 。 如 果 path 为 null, MapPath 方法 将 返回 包含 当 
前 应 用 程序 的 目录 的 完整 物理 路 径 。 

2. Transfer 方法 

Transfer 方法 对 于 当前 请 求 , 终 止 当前 网 页 的 执行 ,并 使 用 指定 的 网 页 URL 路 径 开 始 执 
行 一 个 新 网 页 。 新 网 页 执行 后 不 再 返回 原 网 页 。 其 语法 格式 如 下 : 


Server. Transfer(url); 


其 中 ,url 表示 服务 器 要 执行 的 新 网 页 的 URL 路 径 。Transfer 方法 转向 的 网 页 也 应 该 
是 . aspx 类 型 的 网 页 ,例如 ,传输 到 . asp 或 . asmx 等 类 型 的 网 页 是 无 效 的 。Transfer 方法 保留 
QueryString 和 Form 集合 。 

注意 : 在 使 用 Server 对 象 的 Transfer 方法 时 ,ASP.NET 并 不 验证 当前 用 户 是 否 有 权 查 
看 由 Transfer 方法 提交 的 资源 。 虽 然 ASP.NET 授权 和 身份 验证 逻辑 运行 于 调用 原始 资源 
处 理 程序 之 前 ,但 ASP. NET 仍 将 直接 调用 Transfer 方法 指示 的 处 理 程 序 , 并 且 不 为 新 资源 
重新 运行 授权 和 身份 验证 逻辑 ,这 一 点 不 同 于 Response 对 象 的 Redirect 方法 。 

3. Execute 方法 

有 时 用 户 希 望 在 网 页 运行 时 执行 其 他 网 页 的 内 容 后 继续 执行 当前 网 页 的 内 容 , 可 以 使 用 
Server. Execute 方 法。 其 两 种 用 法 的 语法 格式 如 下 : 


Server. Execute( path); 
Execute( path, preserveForm) 


其 中 ,path 指出 要 执行 的 URL 路 径 ; preserveForm 是 一 个 bool 值 , 当 为 true 时 保留 
QueryString 和 Form 集合 ,为 false 时 清除 QueryString 和 Form 集合 。 

注意 : Execute 方法 和 Transfer 方法 的 区 别 是 Execute 方法 执行 完 新 的 网 页 后 再 返回 原 
网 页 执行 ,而 Transfer 方法 不 再 返回 原 网 页 执行 。 它 们 的 相同 点 是 都 不 同 于 Response 对 象 
的 Redirect 方法 ,执行 它们 时 ASP.NET 不 验证 当前 用 户 是 否 有 权 查 看 由 Execute/Transfer 


5.5.3 Server 对 象 的 应 用 


本 节 通 过 一 个 示例 说 明 Server 对 象 的 应 用 。 

【 例 5.6】 在 ch5 网 站 中 设计 一 个 网 页 WebForm6 ,其 功能 是 使 用 Server 对 象 获取 服务 
器 端的 相关 信息 。 

解 : 其 步骤 如 下 。 

@ 打开 ch5 网 站 ,添加 一 个 网 页 WebForm6. aspx。 

@ 其 设计 界面 如 图 5. 10 所 示 , 其 中 包含 两 个 命令 按钮 (Buttonl 和 Button2) 和 两 个 标签 
(Labell 和 Label2) 。 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Button1_Click(object sender, EventArgs e) 

{ Labell.Text = "服务 器 名 称 :" + Server.MachineName + "<br>" + 
"网 页 请 求 超时 时 间 :"” + Server. ScriptTimeout. ToString() +" 秒 "; 

} 
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protected void Button2_Click(object sender, EventArgs e) 
{ ”string mystrl = "<b> 一 个 字符 串 </b>"; 

string mystr2 = "abl2&@ * 名 #"; 

Label2. Text = "服务 器 路 径 :” + Server.MapPath(".") + "<br>" + 
"HtmlEncode:" + Server.HtmlEncode(mystrl) + "<br>" + 
"HtmlDecode:" + Server.HtmlDecode(mystr1l) + "<br>" + 
"UrlEncode:" + Server.UrlEncode(mystr2) + "<br>" + 
"UrlDecode:" + Server.UrlDecode(mystr2); 

} 


@ 单 击 工具 栏 中 的 p> imiemet Explorer 按钮 运行 本 网 页 ,然后 分 别 单 击 其 中 的 两 个 命令 按钮 ， 
其 结果 如 图 5. 11 所 示 , 从 中 看 到 Server 对 象 的 相关 属性 值 和 通过 调用 Server 对 象 的 相关 方 
法 返回 的 结果 。 


他， 


使 用 Server 对 象 的 属性 
Labell 


[使 用 Server 对 象 的 方法 


[Label2] _ 


设计 | 器 折 分 |。 源 | [4] <asp:tabet.b] 


图 5. 10 WebForm6 网 页 设计 界面 图 5.11 WebForm6 网 页 运行 界面 


5.6 Application 对 象 


Application 对 象 是 为 当前 Web 请 求 获取 的 HttpApplicationState 对 象 , 它 启用 ASP . 
NET 应 用 程序 中 多 个 会 话 和 请 求 之 间 的 全 局 信息 共享 。Application 对 象 是 运行 在 Web 应 用 
服务 器 上 的 虚拟 目录 及 其 子 目录 下 所 有 文件 .网 页 .模块 和 可 执行 代码 的 总 和 。 一 旦 网 站 服务 
器 被 打开 ,就 创建 了 Application 对 象 ,所 有 的 用 户 共用 一 个 Application 对 象 并 可 以 对 其 进行 
修改 。Application 对 象 的 这 一 特性 使 得 网 站 设计 者 可 以 方便 地 创建 聊天 室 和 网 站 计数 器 等 
常用 的 Web 应 用 程序 。 

Application 对 象 是 一 个 对 象 集合 ,可 以 看 作 是 存储 信息 的 容器 ,为 所 有 用 户 共享 。 


5.6.1 Application 对 象 的 属性 


Application 对 象 的 常用 属性 及 其 说 明 如 表 5. 11 所 示 。 
表 5.11 Application 对 象 的 常用 属性 及 其 说 明 


属 性 说 明 
AllKeys 获取 Application 集合 中 的 访问 键 
Count 返回 Application 集合 中 的 对 象 个 数 


Contents 获取 对 Application 对 象 的 引用 
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5.6.2 Application 对 象 的 方法 


Application 对 象 的 常用 方法 及 其 说 明 如 表 5. 12 所 示 , 下 面 介绍 几 个 主要 方法 的 用 法 。 
表 5.12 Application 对 象 的 常用 方法 及 其 说 明 


方 法 说 明 

Add 向 Application 集合 中 添加 新 对 象 

Clear 从 Application 集合 中 移 除 所 有 对 象 

Remove 从 Application 集合 中 移 除 指定 名 称 的 对 象 

RemoveAt 从 Application 集合 中 移 除 指定 索引 的 对 象 

RemoveAll 从 Application 集合 中 移 除 所 有 对 象 

Lock 禁止 其 他 用 户 修改 Application 集合 中 的 对 象 

Unlock 允许 其 他 用 户 修改 Application 集合 中 的 对 象 
1. Add 方法 


该 方法 用 于 将 新 对 象 添加 到 Application 集合 中 。 其 语法 格式 如 下 : 

Application. hdd( 字 符 串 ,对 象 值 ) 

其 中 ,“ 字 符 串 ”指定 对 象 名 。 例 如 : 

string strl = "mystr"; 

int intl = 34; 

Application. Add( "var1", str1); 

Application. Add( "var2", int1); 

这 样 Application 集合 中 新 增 了 varl 和 var2 两 个 对 象 ,它们 的 值 分 别 是 “mystr” 和 34。 
用 户 也 可 以 采用 以 下 方式 新 增 对 象 : 

Application["var1l"] = strl; 

Application["var2"] = intl; 

可 以 采用 以 下 方式 读 取 Application 集合 中 的 信息 : 

int intvar; 

string strvar; 


object objl = Application[0]; // 或 objl = Application.Contents[0]; 
objecto bj2 = Application[ "var2"]; // 或 obj2= Application.Contents[ "var2"]; 
strvar = (string)objl; // 强 制 转换 类 型 


intvar = (int)Application[ "var2"]; // 强 制 转换 类 型 

如 果 Application 集合 中 指定 的 对 象 不 存在 , 则 访问 该 对 象 时 返回 null。 
2. Remove 和 RemoveAt 方法 

它们 都 用 于 删除 Application 集合 中 的 指定 对 象 。 其 使 用 语法 格式 如 下 : 


Application. Remove( 对 象 名 ); 
Application. RemoveAt( 对象 索引 ); 


例如 : 


Application. Remove( "var1") // 删 除 varl 对 象 
Application. RemoveAt (1); // 删 除 var2 对 象 
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5.6.3 Application 对 象 的 事件 


Application 对 象 的 常用 事件 及 其 说 明 如 表 5. 13 所 示 , 这 些 事件 处 理 过 程 应 该 放 在 
Global. asax 文件 中 。 


表 5.13 ” Application 对 象 的 常用 事件 及 其 说 明 


事件 说 明 
Start 在 整个 ASP. NET 应 用 程序 第 一 次 执行 时 引发 
End 在 整个 ASP. NET 应 用 程序 结束 时 引发 


5.6.4 几 种 常见 功能 的 实现 


应 用 程序 状态 是 可 供 ASP.NET 应 用 程序 中 的 所 有 类 使 用 的 数据 储存 库 。 它 存储 在 服务 
器 的 内 存 中 ,因此 与 在 数据 库 中 存储 和 检索 信息 相 比 , 它 的 执行 速度 更 快 。 与 特定 于 单个 用 户 
会 话 的 会 话 状 态 不 同 , 应 用 程序 状态 应 用 于 所 有 的 用 户 和 会 话 。 因 此 ,应 用 程序 状态 非常 适合 
存储 那些 数量 少 , 不 随 用 户 的 变化 而 变化 的 常用 数据 。 

应 用 程序 状态 存储 在 HttpApplicationState 类 中 ,该 类 是 用 户 首次 访问 应 用 程序 中 的 任 
何 URL 资源 时 创建 的 一 个 新 实例 。 

1. 用 锁定 方法 将 值 写 入 应 用 程序 状态 

应 用 程序 状态 变量 可 以 同时 被 多 个 线程 访问 。 因 此 ,为 了 防止 产生 无 效 数 据 , 在 设置 值 
前 ,必须 锁定 应 用 程序 状态 。 

其 实现 方式 是 在 设置 应 用 程序 变量 的 代码 中 调用 Application 对 象 的 Lock 方法 ,并 设置 
应 用 程序 状态 值 ,然后 调用 Application 对 象 的 UnLock 方法 取消 锁定 应 用 程序 状态 ,释放 应 
用 程序 状态 以 供 其 他 写 人 请 求 使 用 。 

例如 ,以 下 代码 说 明了 如 何 锁定 和 取消 锁定 应 用 程序 状态 。 该 代码 将 PageRequestCount 
变量 值 增加 1, 然后 取消 锁定 应 用 程序 状态 : 

Application. Lock(); 

Application["PageRequestCount"] = ((int)Application["PageRequestCount"])+1; 

Application. UnLock( ); 

2. 从 应 用 程序 状态 中 读 取 值 

确定 应 用 程序 变量 是 否 存在 ,然后 在 访问 该 变量 时 将 其 转换 为 相应 的 类 型 。 

例如 ,以 下 代码 说 明了 检索 应 用 程序 状态 值 AppStartTime, 并 将 其 转换 为 一 个 DateTime 
类 型 的 名 为 appStateTime 的 变量 : 

if (Application["AppStartTime"] != null) 

{ 


DateTime myAppStartTime = (DateTime)Application["AppStartTime"]; 
} 


5.6.5 Application 对 象 的 应 用 


本 节 通 过 一 个 示例 说 明 Application 对 象 的 应 用 。 
【 例 5.7】 在 ch5 网 站 中 设计 一 个 网 页 WebForm7, 用 于 实现 简单 的 聊天 室 功 能 。 
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解 : 其 步骤 如 下 。 

@ 打开 ch5 网 站 ,添加 一 个 网 页 WebForm7. aspx。 

@ 其 设计 界面 如 图 5. 12 所 示 , 其 中 包含 3 个 文本 框 ,chatBox 用 于 显示 聊天 内 容 ( 大 小 为 
200pxX 500px, TextMode 属性 置 为 MultiLine, ReadOnly 属性 置 为 True), TextBoxl 和 
TextBox2 分 别 用 于 输入 姓名 和 聊天 记录 ,TextBox2 的 TextMode 属性 被 设 为 MultiLine。 另 
外 有 两 个 命令 按钮 (Buttonl 用 于 提交 聊天 记录 ,Button2 用 于 刷新 聊天 记录 )。 在 该 网 页 上 设 
计 如 下 事件 过 程 : 

protected void Application Start(object sender, EventArgs e) 

{ Application["chats"] = null; // 聊 天 记录 置 空 

Rpplication[ "chatnum"] = null; // 聊 天 记录 数 置 空 


} 
protected void Application_End(object sender, EventArgs e) 
{ Application["chats"] = null; // 聊 天 记录 清空 
Rpplication[ "chatnum"] = null; // 聊 天 记录 数 清空 
} 
protected void Page Load( object sender, EventArgs e) 
{ if (Application["chats"] != null) 
chatBox. Text = Application["chats"].ToString(); 
} 
protected void Buttonl_Click(object sender, EventArgs e) 
4 int num; 
if (TextBox1. Text != "" && TextBox2.Text != "") 
{ Application.Lock(); 
if (Application["chatnum"] == null) 


num = 0; 
else 
num = int.Parse(Application["chatnum"].ToString()); 
if (num % 5 == 0) // 每 5 条 聊天 记录 添加 一 个 当前 时 间 


Application["chats"] = TextBoxl.Text + "说 :" + TextBox2.Text 
+ "[" + DateTime. Now.ToString() + "].\n" + Application["chats"]; 
else 
Application["chats"] = TextBoxl.Text + "说 :" + TextBox2.Text + ".\n" 
+ Application[ "chats"]; 
num++; 


object obj = num; 
Application[ "chatnum" ] = obj; 
Application. UnLock( ); 
chatBox. Text = Application["chats"].ToString(); 
} 
else 
Response. Write("< script > alert( ' 必 须 输入 姓名 和 聊天 内 容 ')</script >"); 
} 
protected void Button2_Click(object sender, EventArgs e) 
{ 证 (TextBoxl.Text != "") 
chatBox. Text = Application["chats"].ToString(); 
} 


说 明 : 由 于 文本 框 的 内 容 较 多 时 总 是 定位 开头 的 位 置 , 为 了 能 够 看 到 最 新 的 聊天 记录 ,所 
以 chatBox 文本 框 的 聊天 记录 是 倒 着 显示 的 。 
@ 单 击 工 具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,输入 姓名 开始 聊天 。 再 次 启动 另 一 
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村 


| 
sat ] 日 拆 分 | * 天 | [4][<formsforml>|[<dv>] <asp:Button#Button2> 四 
5.12 WebForm7 网 页 设计 界面 


chatBox 


个 浏览 器 (如 百度 浏览 器 ) ,输入 地 址 "http://localhost:53072/WebForm7. aspx” 启 动 本 网 页 ， 
这 样 两 个 人 就 可 以 相互 聊天 了 ,图 5. 13 所 示 是 王 华 的 聊天 界面 (采用 I 下 浏览 器 ), 图 5.14 所 
示 是 李 明 的 聊天 界面 (采用 百度 浏览 器 ) 。 


PE 


| < [S TT DP- cl 


简单 聊天 室 
李 明 说 :Bye[2015/4/29 7:51:32]. 
: 等 会 儿 见 . 


: 我 也 准 各 去 . 
李 明 说 :我 准备 去 实验 室 [2015/4/29 7:47:59]. 
王 华 说 :你 计划 干 点 什么 啊 . 
李 明 说 : 没有 看 到 通知 . 
王 华 说 :今天 晚上 班 里 有 什么 活动 ? . 
李 明 说 : 王 华 : 
王 华 说 :大 家 好 [2015/4/29 7: 44:20]. 


好 的 ， 等 会 儿 见 


姓名 : [ 王 理 内 容 : 


图 5.13 WebForm7 网 页 运行 界面 一 


本 网 页 设计 的 说 明 如 下 : 

Oz 程序 中 Response. Write(" 二 script 之 alert( ' 必 须 输入 姓名 和 聊天 内 容 ') 二 /script 这 ") 
语句 是 向 客户 端 浏览 器 发 送 脚本 语句 ,会 在 浏览 器 中 输出 一 个 alert 对 话 框 。 

@ Application_Start 和 Application_End 两 个 事件 过 程 用 于 在 应 用 程序 启动 和 退出 时 执 
行 Application ["chats"]=null 等 将 聊天 记录 清空 。 

@ 本 网 页 不 能 即时 显示 另 一 个 网 友 的 聊天 信息 ,只 有 在 单 击 “ 提 交 ” 按 钮 后 才 显 示 所 有 网 
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am_ox 
他 httpyNocalhost5307:5 v 》 回 图 四 之 三 


PT 
李 明 说 :Bye[2015/4/29 7:51:32]. 
x 会 儿 见 . 


李 明 说 : 王 华 好 . 
王 华 说 : 大 家 好 [2015/4/29 7:44:20]. 


| 内 容 剧 新 | 


Bye 


姓名 : | 李 明 


图 5.14 WebForm7 网 页 运行 界面 二 


友 的 及 时 聊天 信息 ,因此 增加 了 一 个 “内 容 刷 新 ”按钮 ,用 于 实现 刷新 功能 ,可 以 使 用 AJAX 控 
件 进 行 改进 ,有 关 AJAX 控件 的 内 容 在 第 11 章 介 绍 。 


5.7 Session 对 象 


Session 对 象 是 一 个 会 话 对 象 ,是 HttpSessionState 类 对 象 。 就 Web 开发 而 言 , 一 个 会 i 
就 是 客户 通过 浏览 器 与 服务 器 之 间 的 一 次 通话 。 由 于 HTTP 是 无 状态 的 ,因此 无 法 纪录 客户 
一 连 串 的 动作 ,必须 有 一 种 机 制 使 服务 器 能 认得 客户 ,这 就 引入 了 会 话 概念 。 服 务 器 发 给 客户 
一 个 会 话 IDCSessionID) , 当 客户 再 访问 服务 器 时 就 带 着 这 个 ID, 服 务 器 就 赁 着 这 个 唯一 的 ID 
来 识别 客户 。 当 用 户 请 求 一 个 ASP.NET 网 页 时 ,系统 将 自动 创建 一 个 Session 对 象 , 退 出 应 
用 程序 或 关闭 服务 器 时 该 会 话 撤销 。 

和 Application 对 象 一 样 ,Session 对 象 也 是 一 个 对 象 集合 ,但 Session 是 针对 某 个 特定 客 
户 的 ,客户 之 间 不 会 产生 共享 情况 。 


5.7.1 Session 对 象 的 属性 
Session 对 象 的 常用 属性 及 其 说 明 如 表 5. 14 所 示 。 
表 5.14 Session 对 象 的 常用 属性 及 其 说 明 


属 性 说 明 
Contents 获取 对 当前 会 话 状 态 对 象 的 引用 
Count 获取 会 话 状态 集合 中 的 项 数 
JsCookieless 获取 一 个 值 , 该 值 指示 会 话 ID 是 嵌入 在 URL 中 还 是 存储 在 HTTP Cookie 中 
JsNewSession 获取 一 个 值 ,该 值 指示 会 话 是 不 是 与 当前 请 求 一 起 创建 的 
SessionID 用 来 标识 一 个 Session 对 象 


TimeOut 获取 并 设置 会 话 状态 提供 程序 终止 会 话 之 前 各 请 求 之 间 所 人 允许 的 超时 期 限 
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5.7.2 Session 对象 的 方法 
Session 对 象 的 常用 方法 及 其 说 明 如 表 5. 15 所 示 ,下 面 介绍 几 个 主要 方法 的 用 法 。 
表 5.15 ”Session 对 象 的 常用 方法 及 其 说 明 


方 法 说 明 
Add 将 新 的 项 添加 到 Session 集合 中 
Clear 从 Session 集合 中 清除 所 有 对 象 ,但 不 结束 会 话 
Abandon 强行 结束 用 户 会 话 , 并 清除 会 话 中 的 所 有 信息 
CopyTo 将 Session 集合 复制 到 一 维 数 组 中 
Remove 删除 会 话 状 态 集合 中 的 项 
RemoveAll 从 会 话 状态 集合 中 移 除 所 有 的 键 和 值 
RemoveAt 删除 会 话 状态 集合 中 指定 索引 处 的 项 

1. Add 方法 


该 方法 用 于 将 新 对 象 添加 到 Session 集合 中 。 其 语法 格式 如 下 : 
Session. hdd( 字 符 串 , 对象 值 ) 
其 中 ,“ 字 符 串 ” 指 定 对 象 名 。 例 如 : 


string strl = "mystr"; 

int intl = 34; 

Session. Add( "varl1", str1); 
Session. Add( "var2", int1); 


这 样 Session 集合 中 新 增 了 varl 和 var2 两 个 对 象 ,它们 的 值 分 别 是 “mystr” 和 34。 用 户 
也 可 以 采用 以 下 方式 新 增 对 象 : 

Session[ "var1"] = strl; 

Session[ "var2"] = int1; 

可 以 采用 以 下 方式 读 取 Session 集合 中 的 信息 : 


int intvar; 

string strvar; 

object objl = Session[0]; 
objecto bj2 = Session[ "var2" ]; 


strvar = (string)objl; // 强 制 转换 类 型 
intvar = (int)Session["var2"]; // 强 制 转换 类 型 
2. Clear 方 法 


该 方法 用 于 清除 Session 集合 中 的 所 有 对 象 。 其 语法 格式 如 下 : 


Session. Clear(); 


5.7.3 Session 对 象 的 事件 
Session 对 象 的 常用 事件 及 其 说 明 如 表 5. 16 所 示 。 
表 5. 16 Session 对 象 的 常用 事件 及 其 说 明 
事件 说 明 


Start 建立 Session 对 象 时 引发 
End 结束 Session 对 象 时 引发 
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说 明 : 当 用 户 在 客户 端 直接 关 闭 浏览 器 退出 Web 应 用 程序 时 ,并 不 会 触发 End 事件 , 因 
为 关闭 浏览 器 的 行为 是 一 种 典型 的 客户 端 行为 ,是 不 会 被 通知 到 服务 器 端的 。End 事件 只 有 
在 服务 器 重新 启动 用户 调用 了 Abandon 方法 或 未 执行 任何 操作 达到 了 Timeout 设置 的 值 
(〈 超 时) 时 才 会 被 触发 。 


5.7.4 Session 对 象 的 应 用 


本 节 通 过 示例 说 明 Session 对 象 的 应 用 。 

【 例 5.8】 在 ch5 网 站 中 设计 两 个 网 页 WebForm8 和 WebForm8-1 ,用 于 实现 在 这 两 个 
网 页 之 间 传 递 数 据 的 功能 。 

解 : 其 步骤 如 下 。 

@ 打开 ch5 网 站 ,添加 一 个 网 页 WebForm8. aspx。 

@ 其 设计 界面 如 图 5. 15 所 示 , 其 中 包含 两 个 文本 框 (TextBoxl 和 TextBox2 ,分 别 用 于 
输入 用 户 名 和 密码 , TextBox2 的 TextMode 属性 设置 为 Password) 和 一 个 命令 按钮 
(Button1)。 在 该 网 页 上 设计 如 下 事件 过 程 : 


Protected void Button1_Click(object sender, EventArgs e) EY | 局 


{ Session["uname"] = TextBoxl. Text; 


Session["upass"] = TextBox2.Text; 密码 : | 
y Server. Transfer( "WebForm8 — 1.aspx" ); | 确定 | 
> Ss 0 二 1 页 1 5 » 
9 再 添加 个 名 称 为 aspx 的 网 页 其 Ww | = |= 吾 | | 了 
中 只 有 一 个 标签 Labell, 在 该 网 页 上 设计 如 下 事件 过 程 : RE 
protected void Page_Load( object sender, EventArgs e) 图 5.15 WebForm8 网 页 设计 界面 


{ string mystr; 
mystr = "用 户 名 :" + Session["uname"].ToString() + 
"<br> 密 码 :" + Session["upass"].ToString(); 
Labell. Text = mystr; 
} 


@ 单 击 工 具 栏 中 的 Pp Imternet Explorer 按钮 运行 WebForm8 网 页 ,输入 用 户 名 和 密码 ,如 
图 5.16 所 示 。 单 击 “ 确 定 ” 按 钮 ,转向 WebForm8-1. aspx 网 页 ,输出 结果 如 图 5. 17 所 示 。 


< | tp//ocalhosts307: p ~ ©| 研 
愿 localhost x 
用 户 名 : | 王 华 
密码 : 。 [oooed 
5.16 ”WebForm8 网 页 运行 界面 图 5.17 WebForm8-1 网 页 运行 界面 
从 本 例 可 以 看 到 .在 一 次 会 话 中 , Session 对 象 中 存储 的 值 都 是 有 效 的 ,这 里 是 在 


WebForm8 网 页 中 存储 用 户 名 和 密码 ,在 WebForm8-l 网 页 中 使 用 这 些 值 。 
在 设计 网 站 时 ,有 时 需要 禁止 用 户 后 退 或 者 刷新 以 及 重复 提交 数据 ,解决 方法 有 多 种 ,可 
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以 通过 Session 对 象 来 解决 ,其 思路 是 设置 一 个 标志 ,将 这 个 标志 放 在 Session 中 ,在 提交 命令 
按钮 Buttonl 中 设计 相应 的 判断 功能 .基本 代码 如 下 : 


protected void Page_Load(object sender, EventArgs e) 
{ if (!Page. IsPostBack) 
{ ”// 如 果 第 一 次 载 入 网 页 就 将 Updata 设 为 False 
Session[ "Updata"] = False; 
} 


} 
protected void Buttonl_Click(object sender, EventArgs e) 


{ ” // 如 果 网 页 已 经 提交 过 (Updata 为 true) 则 不 进行 任何 操作 , 直接 返回 
if (Session[ "Updata"] == True) return 
// 这 里 放置 表单 验证 代码 ,验证 正确 后 将 Updata 设 为 True 
Session["Updata"] = True; 
// 这 里 放置 转向 其 他 网 页 的 代码 
} 
这 样 用 户 只 要 成 功 提交 之 后 ,在 提交 过 程 中 刷新 网 页 或 提交 一 次 后 单 击 后 退 按钮 都 不 能 
再 反复 提交 了 。 


5.8 Cookie 对 象 


Response 和 Request 对 象 都 有 一 个 Cookies 属性 , 它 是 存放 Cookie 对 象 的 集合 , 是 
HttpCookieCollection 类 对 象 ,提供 了 操作 Cookie 的 方法 。 而 Cookie 是 HttpCookie 类 对 象 ， 
提供 创建 和 操作 各 Cookie 的 方法 。 一 个 Cookie 是 一 段 文本 信息 ,能 随 着 用 户 请 求 和 网 页 在 
Web 服务 器 和 浏览 器 之 间 传 递 。 用 户 每 次 访问 站 点 时 , Web 应 用 程序 都 可 以 读 取 Cookie 包 
含 的 信息 ,从 而 知道 用 户 上 次 登录 的 时 间 等 具体 信息 。Cookie 可 以 是 临时 的 (具有 特定 的 过 
期 时 间 和 日 期 ), 也 可 以 是 永久 的 。 

Cookie 对 象 和 Application、Session 对 象 一 样 ,都 是 为 了 保存 信息 ,它们 之 间 的 区 别 是 
Cookie 对 象 的 信息 保存 在 客户 端 ,而 Application 和 Session 对 象 的 信息 保存 在 服务 器 端 。 

通常 使 用 Response 对 象 的 Cookies 集合 属性 设置 Cookie 信息 ,使 用 Request 对 象 的 
Cookies 集合 属性 读 取 Cookie 信息 。Cookies 集合 属性 有 Count( 返 回 集合 中 Cookie 对 象 的 
个 数 ) 属 性 和 Add( 向 Cookies 集合 中 新 增 一 个 Cookie 对 象 ) .Clear( 删 除 Cookies 集合 中 的 所 
有 对 象 ) 及 Remove( 删 除 Cookies 集合 中 指定 名 称 的 对 象 ) 等 方法 。 


5.8.1 Cookie 对 象 的 属性 


Cookie 对 象 的 常用 属性 及 其 说 明 如 表 5. 17 所 示 , 下 面 介绍 其 中 几 个 主要 的 属性 。 
表 5.17 Cookie 对 象 的 常用 属性 及 其 说 明 


属 性 说 明 
Name 获取 或 设置 Cookie 的 名 称 
Expires 获取 或 设置 Cookie 的 过 期 日 期 和 时 间 
Domain 获取 或 设置 Cookie 关联 的 域 
Path 获取 或 设置 要 与 Cookie 一 起 传输 的 虚拟 路 径 
Secure 获取 或 设置 一 个 值 ,通过 该 值 指示 是 否 安全 传输 Cookie 
ltem 获取 HttpCookie. Values 属性 的 快捷 方式 
Value 获取 或 设置 单个 Cookie 值 


Values 获取 在 单个 Cookie 对 象 中 包含 的 键 值 对 的 集合 
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1. Name 属性 

通过 Cookie 的 Name 属性 来 指定 Cookie 的 名 称 , 因 为 Cookie 是 按 名 称 保存 的 ,如 果 设 置 
了 两 个 名 称 相同 的 Cookie, 后 保存 的 那 一 个 将 覆盖 前 一 个 ,所 以 在 创建 多 个 Cookie 时 ,每 个 
Cookie 都 必须 具有 唯一 的 名 称 , 以 便 日 后 读 取 时 识别 。 

例如 ,mycookie 是 一 个 Cookie 对 象 , 则 mycookie. Name 返回 该 Cookie 对 象 的 名 称 。 

2. Value 属性 

Cookie 的 Value 属性 用 来 指定 Cookie 中 保存 的 值 ,因为 Cookie 中 的 值 都 是 以 字符 串 的 
形式 保存 的 ,所 以 当 为 Value 指定 值 时 ,如 果 不 是 字符 串 类 型 的 要 进行 类 型 转换 。 

例如 ,mycookie 是 一 个 Cookie 对 象 , 则 mycookie. Value 返回 该 Cookie 对 象 的 值 。 


5.8.2 Cookie 对 象 的 方法 
Cookie 对 象 的 常用 方法 及 其 说 明 如 表 5. 18 所 示 。 
表 5.18 Cookie 对 象 的 常用 方法 及 其 说 明 


方 法 说 明 
Equals 判断 指定 的 Cookie 对 象 是 否 等 于 当前 的 Cookie 对 象 
ToString 返回 此 Cookie 对 象 的 一 个 字符 串 表 示 形 式 


5.8.3 Cookie 对 象 的 应 用 


1. 创建 Cookie 对 象 

Cookie 对 象 是 由 HttpCookie 类 来 实现 的 ,创建 一 个 Cookie 对 象 就 是 建立 HttpCookie 类 
的 一 个 实例 。HttpCookie 类 具有 以 下 构造 函数 : 

public HttpCookie (string name) 

public HttpCookie(string name, string value) 

其 中 ,name 表示 Cookie 对 象 的 名 称 ( 对 应 Name 属性 ) ,value 表示 Cookie 对 象 的 值 ( 对 
应 Value 属性 )。 例 如 : 

HttpCookie cookiel = new HttpCookie("mycookiel"); 

// 新 建 名 称 为 mycookiel 的 Cookie 对 象 

cookiel. Value = "mystring"; // 其 值 设 为 "mystring" 

Response. Cookies. Add( cookiel ); // 添 加 cookiel 对 象 

HttpCookie cookie2 = new HttpCookie("mycookie2", "good"); 

// 新 建 名 称 为 mycookie2 的 Cookie 对 象 ,其 值 为 "good" 

Response. Cookies. Add( cookie2); // 添 加 cookie2 对 象 

2. 设置 多 值 Cookie 

一 个 Cookie 对 象 可 以 有 多 个 值 ,通过 子 键 区 分 。 

例如 , 当 一 个 名 称 为 mycookie 的 Cookie 对 象 已 添加 到 Response 对 象 中 后 ,可 以 通过 以 
下 语句 设置 两 个 子 键 的 值 : 

Response. Cookies["mycookie" ]["uname" ] = "Smith"; 

Response. Cookies["mycookie" ]["uage" ] = 23. ToString(); 

或 者 在 创建 Cookie 对 象 的 同时 设置 多 个 值 : 


HttpCookie cookie = new HttpCookie("mycookie" ) 
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cookie. Values["uname"] = "Smith"; 

cookie. Values["uage"] = 23.ToString(); 

Response. Cookies. Add( cookie); 

3. 读 取 Cookie 对 象 

对 于 单 值 Cookie 对 象 , 直接 用 Request. Cookies[ Cookie 的 Name 属性 值 ] 来 读 取 其 
Cookie 值 。 

对 于 多 值 Cookie 对 象 , 还 需 加 上 子 键 名 称 。 例 如 ,以 下 语句 将 Name 为 mycookiel 的 
Cookie 对 象 的 两 个 子 键 值 分 别 在 两 个 文本 框 中 输出 : 

TextBoxl. Text = Request.Cookies["mycookiel"]["uname"]; 

TextBox2. Text = Request.Cookies["mycookiel"]["uvage"]; 

4. Cookie 的 有 效 期 

Cookie 的 Expires 属性 是 DateTime 类 型 的 ,用 来 指定 Cookie 的 过 期 日 期 和 时 间 , 即 
Cookie 的 有 效 期 。 浏 览 器 在 适当 的 时 候 删 除 已 经 过 期 的 Cookie。 如 果 不 给 Cookie 指定 过 期 
日 期 和 时 间 , 则 为 会 话 Cookie, 不 会 存 人 用 户 的 硬盘 ,在 浏览 器 关闭 后 就 会 被 删除 。 

应 根据 应 用 程序 的 需要 来 设置 Cookie 的 有 效 期 ,如 果 用 来 保存 用 户 的 首选 项 , 则 可 以 把 
其 设置 为 永远 有 效 ( 例 如 100 年 ); 如 果 用 来 统计 用 户 访问 次 数 , 则 可 以 把 有 效 期 设置 为 半年 。 
即使 设置 长 期 有 效 , 用 户 也 可 以 自行 决定 将 其 全 部 删除 。 

5. 修改 和 删除 Cookie 

修改 某 个 Cookie 实际 上 是 指 用 新 的 值 创建 新 的 Cookie, 并 把 该 Cookie 发 送 到 浏览 器 , 覆 
六 客户 机 上 旧 的 Cookie。 

删除 Cookie 是 修改 Cookie 的 一 种 形式 。 由 于 Cookie 位 于 用 户 的 计算 机 中 ,所 以 无 法 直 
接 将 其 删除 。 但 是 ,用 户 可 以 修改 Cookie 将 其 有 效 期 设置 为 过 去 的 某 个 日 期 ,从 而 让 浏览 器 
删除 这 个 已 过 期 的 Cookie。 

【 例 5.9】 在 ch5 网 站 中 设计 一 个 网 页 WebForm9 
其 功能 是 说 明 Cookie 对 象 的 使 用 方法 。 | 

解 : 其 步骤 如 下 。 | 

@ 打开 ch5 网 站 ,添加 一 个 网 页 WebForm9. aspx。 | CT | 

@ 其 设计 界面 如 图 5. 18 所 示 , 其 中 包含 两 个 文 =- 
本 框 (TextBoxl 和 TextBox2 ) 和 两 个 命令 按钮 | 1 


设计 | 日 拆 分 |。 源 | |4] <asp:Buttonauto- 
(Buttonl 和 Button2)。 在 该 网 页 上 设计 如 下 事件 ” 
过 程 ; 图 5.18 ”WebForm9 网 页 设计 界面 


protected void Buttonl1_Click(object sender, EventArgs e) 
{ ”// 写 人 Cookie 事件 过 程 
HttpCookie mycookie = new HttpCookie("cookiemc"); 
mycookie. Value = TextBoxl.Text; 
mycookie. Expires = DateTime. Now. AddMinutes(1); // 保 存 1 分 钟 
Response. Cookies. Rdd(mycookie) ; // 添 加 到 Response 对 象 中 
} 
protected void Button2_Click(object sender, EventArgs e) 
{ ”// 读 取 Cookie 事件 过 程 
if (Request. Cookies[ "cookiemc"] != null) 
TextBox2. Text = Request.Cookies["cookiemc"].Value; 
else 
Response. Write("< script > alert( 'Cookie 已 过 期 ')</script >"); 
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@ 单 击 工 具 栏 中 的 Internet Explorer 按钮 运行 本 网 页 ,在 TextBoxl 文本 框 中 输入 “China” 
字符 串 ,然后 单 击 * 写 人 Cookie” 命 令 按 钮 ,再 单 击 “ 读 取 Cookie” 命 令 按钮 , 则 在 TextBox2 文 
本 框 中 输出 Cookie 的 值 ,如 图 5. 19 所 示 。 由 于 Request. Cookies[ "cookiemc"] 的 保留 时 间 被 
设置 为 1 分钟 , 当 到 期 后 , 单 击 “ 读 取 Cookie” 命 令 按钮 会 出 现 如 图 5. 20 所 示 的 消息 提示 框 , 表 
示 该 Cookie 不 能 再 使 用 。 


图 5. 19 WebForm9 网 页 运行 界面 图 5.20 消息 提示 框 


说 明 : Cookies 是 Cookie 的 集合 ,Page 对 象 并 没有 Cookies 属性 ,所 以 要 保存 Cookie 信 
息 , 应 将 其 添加 到 Response 对 象 中 ,由 Request 对 象 读 出 来 使 用 。 


5.9 ViewState 对 象 


ViewState 对 象 是 视图 状态 对 象 , 它 是 Page 对 象 的 一 个 属性 ,是 StateBag 类 对 象 。 视 图 
状态 是 ASP.NET 网 页 框架 默认 情况 下 用 于 保存 往返 过 程 之 间 的 网 页 和 控件 值 的 方法 。 视 图 
状态 用 于 在 同一 网 页 的 多 个 请 求 间 保存 和 还 原 服务 器 控件 的 信息 。 当 呈现 网 页 的 HTML 形式 
时 ,需要 在 回 发 过 程 中 保留 的 网 页 的 当前 状态 和 值 将 被 序列 化 为 Base64 编码 的 字符 串 , 并 输出 
到 视图 状态 的 隐藏 字段 中 。 在 第 1 章 的 例 1. 1 中 看 到 的 服务 器 运行 WebForml 网 页 后 发 送 给 客 
户 端的 代码 中 ,VIEWSTATE、_VIEWSTATEGENERATOR 和 _EVENTVALIDATION 
就 是 这 样 的 隐藏 字段 ,它们 的 值 是 一 串 乱码 ,实际 上 是 序列 化 的 结果 。 

用 户 可 以 通过 使 用 网 页 的 ViewState 属性 将 往返 过 程 中 的 数据 保存 到 Web 服务 器 来 利 
用 自己 的 代码 访问 视图 状态 。ViewState 属性 是 一 个 包含 密 钥 / 值 对 (其 中 包含 视图 状态 数 
据 ) 的 字典 。 可 以 存储 在 视图 状态 中 的 数据 类 型 有 字符 串 、 整 数 、 布 尔 值 ,Array 对 象 、 
ArrayList 对 象 和 哈 希 表 等 。 


5.9.1 ViewState 对 象 的 属性 


ViewState 对 象 的 常用 属性 及 其 说 明 如 表 5. 19 所 示 。 
表 5.19 ViewState 对 象 的 常用 属性 及 其 说 明 


属 性 说 明 
Count 获取 视图 状态 对 象 中 的 状态 项 个 数 
ltem 获取 或 设置 在 视图 状态 对 象 中 存储 的 项 的 值 
Keys 获取 表示 视图 状态 对 象 中 的 项 的 键 集合 


Values 获取 存储 在 视图 状态 对 象 中 的 视图 状态 值 的 集合 


第 5 章 ASP.NET 的 常用 对 


5.9.2 ViewState 对 象 的 方法 


ViewState 对 象 的 常用 方法 及 其 说 明 如 表 5. 20 所 示 。 
表 5.20 ViewState 对 象 的 常用 属性 及 其 说 明 


方 法 说 明 
Add 将 新 的 状态 项 对 象 添加 到 StateBag 对 象 。 如 果 该 项 已 经 存在 于 视图 状态 对 象 中 ， 
则 此 方法 会 更 新 该 项 的 值 

Clear 从 当前 视图 状态 对 象 中 移 除 所 有 项 

Remove 将 指定 的 密 钥 / 值 对 从 视图 状态 对 象 中 移 除 
例如 ， 
RrrayList myarr = new ArrayList(4); // 定 义 名 为 myarr 的 ArrayList 对 象 
myarr. Add( "item 1"); // 向 myarr 中 添加 4 个 元 素 


myarr. Add(" item 2"); 
myarr. Add( " item 3"); 
myarr. Rdd(" item 4"); 


ViewState. Add( "mystate", myarr); // 将 myarr 存储 到 键 名 为 mystate 的 视图 项 中 
ArrayList parr; // 声 明 parr 
parr = (RrrayList)ViewState[ "mystate" ] ; // 读 取 键 名 为 mystate 的 视图 项 到 parr 中 


说 明 : 视图 状态 信息 是 使 用 Base64 编码 存储 的 ,并 在 呈现 期 间 包 括 在 网 页 中 ,这 会 增加 
网 页 大 小 。 在 回 发 网 页 时 ,视图 状态 的 内 容 作为 网 页 回 发 信息 的 一 部 分 发 送 。 由 于 这 会 大 大 
增加 网 络 通信 量 和 降低 连接 速度 ,因此 建议 不 要 在 视图 状态 中 存储 大 量 信息 。 


5.9.3 ViewState 对 象 的 应 用 


ViewState 对 象 的 应 用 与 Application Session 十 分 相似 ,只 是 将 相关 的 键 名 和 值 存 储 在 
隐藏 字段 _VIEWSTATE 中 。 

【 例 5.10】 在 ch5 网 站 中 设计 一 个 网 页 WebForml0 ,其 功能 是 说 明 Cookie 对 象 的 使 用 
方法 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch5 网 站 ,添加 一 个 网 页 WebForm10. aspx。 

@ 其 设计 界面 如 图 5. 21 所 示 ,其 中 包含 两 个 文本 框 (TextBoxl 和 TextBox2)、 两 个 命令 
按钮 (Buttonl 和 Button2) 和 一 个 标签 Labell。 在 该 网 页 上 设计 如 下 事件 过 程 : 

protected void Page_Load( object sender, EventArgs e) 

, Button2. Enabled = False; 

tate void Button1_Click(object sender, EventArgs e) 


{ if (TextBoxl. Text != "" && TextBox2.Text != "") | 
{ ViewState[ "name"] = TextBox1l. Text; 外 存储 视图 状态 | 读 取 视图 状态 | 
ViewState[ "age" ] = TextBox2.Text; [cabel 
Button2. Enabled = True; 
} » 
} 5 设 + |a 拆 分 |。 源 | [4| <dw> 时 
EF 
protected void Button2_Click(object sender, EventArgs e) 
{ Labell.Text = "ViewState 信息 如 下 : <br>"; 图 5.21 WebForml0 网 页 设计 界面 
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Labell. Text += "姓名 : " + ViewState[ "name"] + "<br>"; 
Label1. Text += "年 龄 : " + ViewState[ "age"]; 
} 
@@ 单 击 工具 栏 中 的 上 Intemet Explorer 按钮 运行 本 网 页 ,在 TextBoxl 文本 框 中 输入 “ 王 华 ”， 
在 TextBox2 文 本 框 中 输入 *30”, 如 图 5. 22 所 示 , 然 后 单 击 “ 存 储 视图 状态 ”命令 按钮 ,再 单 击 
“ 读 取 视图 状态 ”命令 按钮 , 则 在 Labell 标签 中 输出 存储 的 视图 状态 的 值 ,如 图 5. 23 所 示 。 


呈 PE 人 文 


| 人 npy/ocalhosts307. Pp - © 


[许久 视图 类 态 | | 读 取 视图 状态 | 


ViewState 信 息 如 下 : 
名 : 玉 华 


图 5.22 WebForml0 网 页 运行 界面 一 图 5.23 WebForm10 网 页 运行 界面 二 


5.10 ”配置 Global. asax 文件 


每 个 ASP. NET 网 页 中 都 会 存在 许多 的 事件 ,如 Page_Load 等 ,用 户 可 以 在 网 页 中 通过 
编程 来 处 理 这 些 事 件 。 作 为 一 个 ASP.NET 应 用 程序 也 存在 这 样 的 事件 ,如 应 用 程序 开始 时 
要 执行 什么 操作 ,一 个 新 Session 被 创建 的 时 候 要 进行 什么 操作 等 。 那么 对 这 些 事 件 的 处 理 
要 写 在 什么 地 方 呢 ? 通常 情况 下 这 些 事 件 处 理 过程 应 放 在 Global. asax 和 Web. config 这 两 
个 文件 中 。 有 关 Web. config 文件 的 内 容 将 在 以 后 介绍 ,这 里 只 讨论 Global. asax 文件 。 

在 ASP.NET 中 都 不 会 自动 创建 Global. asax 文件 ,如 果 要 创建 该 文件 ,选择 "网 站 | 添加 
新 项 ”命令 ,在 打开 的 “添加 新 项 ”对 话 框 中 选择 “全 局 应 用 程序 类 ”选项 ,如 图 5. 24 所 示 , 单 击 
“添加 ”按钮 即 可 创建 一 个 Global. asax 文件 。 该 文件 位 于 ASP. NET 应 用 程序 的 根 目录 下 ， 
其 作用 就 是 用 来 处 理 与 应 用 程序 相关 的 一 些 事 件 。 

常用 的 应 用 程序 相关 事件 及 事件 被 触发 时 间 如 表 5. 21 所 示 。 


表 5.21 应 用 程序 相关 事件 


事件 名 称 事件 被 触发 的 时 间 事件 名 称 事件 被 触发 的 时 间 
Application_Start 应 用 程序 启动 时 Application_Error 发 生 错 误 时 
Session_Start 会 话 启动 时 Session_End 会 话 结束 时 
Application_BeginRequest 每 个 请 求 开 始 时 Application_End 应 用 程序 结束 时 


下 面 通过 一 个 示例 说 明 Global. asax 文件 的 作用 。 

【 例 5.11】 在 ch5 网 站 中 设计 一 个 网 页 WebFormll ,其 功能 是 统计 访问 网 页 的 在 线 
人 数 。 

解 : 其 步骤 如 下 。 

@ 打开 ch5 网 站 。 
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图 5.24 添加 Global. asax 文件 


@ 若 本 网 站 中 没有 Global. asax 文件 , 则 添加 一 个 ,否则 打开 该 文件 ,修改 其 内 容 如 下 (只 
添加 粗 体 代 码 部 分 ,其 他 不 变 ): 


<% @ Application Language= "C#" %> 
<script runat = "server"> 
void Application_Start(object sender, EventArgs e) 
{ ”// 在 应 用 程序 启动 时 运行 的 代码 
Application. Lock( ); 
Application["counter"] = 0; 
Application. UnLock( ); 
} 
void Application_End(object sender, EventArgs e) 


{ 
// 在 应 用 程序 关闭 时 运行 的 代码 
} 
void Application_Error(object sender, EventArgs e) 
{ 
// 在 出 现 未 处 理 的 错误 时 运行 的 代码 
类 


void Session_Start(object sender, EventArgs e) 
{ ”VW/ 在 新 会 话 启动 时 运行 的 代码 
Application. Lock( ); 
Application["counter"] = (int)Application["counter"] + 17 
Application. UnLock( ); 
} 
void Session_ End( object sender, EventArgs e) 
{ 
// 在 会 话 结 束 时 运行 的 代码 
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// 注 意 : 只 有 在 Web. config 文件 中 的 sessionstate 模式 设置 为 
//InProc 时 才 会 引发 Session_End 事件 。 如 果 会 话 模式 设置 为 StateServer 
// 或 SQLServer, 则 不 会 引发 该 事件 
Application. Lock( ); 
Application["counter"] = (int)Rpplication[" counter"] - 1; 
Application. UnLock( ); 
} 
</script> 
@ 添加 一 个 WebFormll 的 网 页 ,在 其 中 拖 放 一 个 标签 Labell。 在 该 网 页 上 设计 如 下 事 
件 过 程 : 
Protected void Page_Load( object sender, EventArgs e) 
{ 
Labell. Text = " 当前 在 线 人 数 :" + Application["counter"].ToString(); 
} 
@ 单 击 工具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 ,看 到 在 线 人 数 为 1, 如 图 5. 25 所 示 。 
不 关闭 IE, 再 次 启动 百度 浏览 器 ,并 输入 地 址 *http://localhost:53072/WebFormll1. aspx”， 
此 时 的 网 页 界面 如 图 5. 26 所 示 , 在 线 人 数 变 为 2。 这 是 因为 在 第 一 次 启动 本 网 页 时 ,执行 一 
次 Global. asax 文件 中 的 Application_Start 事件 过 程 ,将 Application[ "counter"] 置 为 0, 则 以 
后 每 次 出 现 一 次 会 话 , 便 执 行 一 次 Global. asax 文件 中 的 Session _Start 事件 过 程 , 使 
Application["counter"] 增 1, 当 退出 会 话 时 ,执行 一 次 Global. asax 文件 中 的 Session_End 事 
件 过 程 ,使 Application[ "counter"] 减 1, 所 以 Application["counter"] 的 值 就 是 在 线 的 人 数 。 


四 《 > BD http//ocalhost'53072/WebFormillaspx 克 | 


图 5.25 “WebFormll 网 页 运行 界面 一 图 5.26 WebFormll 网 页 运行 界面 二 


5.11 ASP.NET 网 页 框架 


在 前 面 的 各 种 示例 中 已 经 介绍 了 动态 网 页 设计 的 基本 方法 ,本 节 归 纳 网 页 执行 和 传统 桌 
面 应 用 程序 执行 的 不 同 点 ,以 及 网 页 的 生命 周期 和 网 页 的 生命 周期 中 的 事件 。 


5.11.1 网 页 的 执行 方式 和 ASP .NET 状态 管理 


当 用 户 在 浏览 器 中 输入 一 个 URL 的 时 候 , 浏 览 器 显示 出 带 有 文本 框 .图 像 、 命 令 按 钮 
或 其 他 网 页 元 素 的 Web 网 页 。 当 用 户 输入 文本 框 内 容 , 然 后 单 击 某 个 提交 按钮 时 ,网 页 上 
就 显示 出 新 的 数据 ,对 用 户 的 操作 进行 响应 。 所 谓 提交 按钮 ,是 指 其 HTML 元 素 的 type 属 
性 为 "submit ”或 者 导致 执行 表单 submit() 方 法 的 网 页 元 素 。 那么 这 一 执行 过 程 是 怎样 
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的 呢 ? 

对 于 传统 的 桌面 应 用 程序 ,有 一 个 用 户 坐 下 来 开始 运行 这 个 应 用 程序 ,并 且 是 在 一 段 时 间 
内 不 停 地 运行 它 ,然后 关闭 这 个 应 用 程序 。 用 户 与 这 个 应 用 程序 进行 交互 的 这 段 时 间 称 为 会 
话 。 如 果 用 户 在 某 个 地 方 输入 他 的 姓名 .应 用 程序 会 在 一 定时 期 内 记 住 这 个 姓名 (这 段 时 期 称 
为 该 变量 的 作用 域 ) ,以 备 随后 使 用 。 用 户 的 姓名 以 及 用 户 所 做 的 其 他 更 改 就 是 所 谓 应 用 程序 
的 状态 Cstate) 。 应 用 程序 至 少 需要 在 同一 会 话 期 间 内 保持 这 个 状态 .有 时 候 需要 在 不 同 会 话 
之 间 保持 这 个 状态 。 

桌面 应 用 程序 总 是 需要 保持 应 用 程序 的 状态 ,而 Web 网 页 不 需要 。 事 实 上 , Web 应 用 程 
序 模型 被 特意 而 明确 地 设计 为 "无 状态 的。 而 Web 用 户 期 待 Web 应 用 程序 能 够 像 桌 面 应 用 
程序 一 样 具有 相同 的 行为 ,所 以 Web 应 用 程序 也 需要 以 某 种 方式 来 保持 状态 。 

吉 人 的 这 通常 意味 着 在 
每 次 往返 过 程 中 将 会 丢失 所 有 与 该 页 面 及 其 控件 关联 的 信息 。 例 如 ,如 果 用 户 将 信息 输入 到 
HTML 网 页 上 的 文本 框 中 ,此 信息 将 发 送 到 服务 器 ,但 是 不 会 返回 到 客户 端 。 为 了 克服 Web 
编程 的 这 一 固有 局 限 性 ,ASP.NET 网 页 框架 包含 几 种 状态 管理 功能 ,可 以 将 往返 过 程 之 间 的 
网 页 和 控件 值 保 存 到 Web 服务 器 。ASP.NET 状态 管理 有 以 下 两 种 方式 。 

1. 基于 客户 端的 状态 管理 方法 

基于 客户 端的 状态 管理 涉及 在 网 页 中 或 客户 端 计算 机 上 存储 信息 ,在 各 往返 行程 间 不 会 
在 服务 器 上 维护 任何 信息 。 其 常见 技术 有 视图 状态 .控件 状态 和 Cookie 等 。 

(1) 视图 状态 

视图 状态 管理 是 通过 使 用 ViewState 对 象 实现 的 ,在 前 面 已 介绍 。 

(2) 控件 状态 

用 户 可 以 使 用 ViewState 属性 来 保存 控件 状态 数据 ,也 可 以 使 用 ControlState 属性 保持 
特定 于 某 个 控件 的 属性 信息 。 

(3) 隐藏 域 

开发 人 员 可 以 在 ASP.NET 网 页 的 表单 中 自己 创建 HiddenField 控件 ( 自 定义 隐藏 域 ) 来 
存储 任何 特定 于 网 页 的 信息 。 隐 藏 域 在 浏览 器 中 不 以 可 见 的 形式 呈现 ,但 可 以 像 对 待 标准 控 
件 一 样 设置 其 属性 。 当 向 服务 器 提交 网 页 时 ,隐藏 域 的 内 容 将 在 HTTP 窗 体 集合 中 随 其 他 控 
件 的 值 一 起 发 送 。 

(4) Cookie 

Cookie 管理 是 通过 使 用 Cookie 对 象 实现 的 ,在 前 面 已 介绍 。 

(5) 查询 字符 串 

查询 字符 串 是 在 网 页 URL 的 结尾 附加 的 信息 。 例 如 : 


http://www. mysite. com/default. aspx?name = smith&age = 30 


在 上 面 的 URL 路 径 中 ,查询 字符 串 以 问号 (?) 开 始 ,并 包含 两 个 属性 / 值 对 ,一 个 名 为 
name, 另 一 个 名 为 age。 

查询 字符 串 提供 了 一 种 维护 状态 信息 的 方法 ,这 种 方法 很 简单 ,但 有 使 用 上 的 限制 。 大 多 
数 浏览 器 和 客户 端 设备 会 将 URL 的 最 大 长 度 限制 为 2083 个 字符 。 

2. 基于 服务 器 的 状态 管理 方法 

ASP.NET 提供 了 多 种 方法 用 于 维护 服务 器 上 的 状态 信息 ,而 不 是 保持 客户 端 上 的 信息 。 
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通过 基于 服务 器 的 状态 管理 ,为 了 保留 状态 ,可 以 减少 发 送 给 客户 端的 信息 量 , 但 它 可 能 会 使 
用 服务 器 上 高 成 本 的 资源 。 其 常见 技术 有 应 用 程序 状态 、 会 话 状态 及 配置 文件 属性 。 

应 用 程序 状态 管理 是 采用 Application 对 象 实现 的 ,会 话 状态 管理 是 采用 Session 对 象 实 
现 的 。 有 关 配 置 文件 属性 的 内 容 将 在 本 章 后 面 介绍 。 

回 到 前 面 的 问题 ,用 户 在 浏览 器 中 输入 一 个 URL, 即 发 出 一 个 网 页 请 求 ,Web 服务 器 找 
到 相应 的 ASP.NET 网 页 ,将 其 交 给 ASP.NET 引擎 ,ASP.NET 引擎 执行 相关 的 程序 代码 ， 
生成 HTML 网 页 文件 ,由 Web 服务 器 发 给 用 户 浏览 器 进行 显示 (并 保存 这 个 网 页 的 相关 信 
息 , 以 便 识别 是 第 一 次 加 载 还 是 回 传 ) ,这 是 第 一 次 网 页 显示 ,其 详细 过 程 如 图 5. 27(a) 
所 示 。 


创建 网 页 (基于 .aspx 文 件 中 
的 标记 ) 折 
请 求 某 个 URL(HTTP get) 
世 oe 国 运行 初始 化 代码 名 
响 
应 
动态 信息 序列 化 到 视图 状态 | 这 
i 二 把 动态 信息 序列 化 到 视图 状 站 
/ 服务 器 喘 
把 网 页 对 象 呈现 为 HTML 
(a) 第 一 次 请 求 
用 户 单 击 某 创建 网 页 (基于 .aspx 文 件 中 
个 提交 按 外 的 标记 ) 
回 发 : 把 网 页 发 送 到 某 
个 URL(HTTP post) 反 序列 化 并 应 用 视图 状态 数据 有 
一 区 四 
运行 初始 化 代码 四 
客户 端 。 四 送 : 返回 呈现 的 HTML 文 档 。 f 应 
服务 器 端 运行 事件 处 理 过 程 过 
Ek 
把 动态 信息 序列 化 到 视图 状态 
i 
把 网 页 对 象 呈现 为 HTML 
(b) 回 传 过 程 


图 5.27 ASP.NET 网 页 请 求 
当 用 户 输入 文本 框 内 容 , 然 后 单 击 命令 按钮 ,这 称 为 提交 (并 非 每 次 用 户 操作 都 要 提交 ,如 
果 有 客户 端 代码 ,如 JavaScript 代码 ,这些 代 码 的 执行 是 在 客户 端 进行 的 ,不 需要 提交 ) ,网 页 
再 次 传 给 Web 服务 器 , Web 服务 器 再 次 交 给 ASP.NET 引擎 ,该 引擎 执行 相关 的 事件 处 理 程 
序 , 又 生成 HTML 网 页 文件 ,由 Web 服务 器 发 给 用 户 浏览 器 进行 显示 ,这 称 为 第 二 次 显示 ,这 
一 过 程 称 为 回 传 过 程 , 其 详细 过 程 如 图 5. 27(b) 所 示 。 这 种 交互 过 程 可 以 一 直 进行 下 去 ,直到 
用 户 终止 执行 。 


5.11.2 网 页 的 生命 周期 


当 请 求 Web 服务 器 上 的 一 个 ASP.NET 网 页 时 ,这 个 网 页 就 会 被 加 载 到 Web 服务 器 的 
内 存 中 ,经 过 处 理 后 ,发 送 给 用 户 , 即 从 内 存 中 印 载 出 去 。 这 个 过 程 称 为 网 页 的 生命 周期 , 它 的 
目标 就 是 为 发 送 网 页 请 求 的 浏览 器 呈现 适当 的 HTML 网 页 。 
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网 页 生命 周期 有 两 种 稍微 不 同 的 顺序 : 一 种 是 首次 加 载 网 页 时 , 另 一 种 是 在 回 传 过 程 中 
再 次 加 载 网 页 时 ,图 5. 28 说 明了 网 页 生命 周期 的 各 个 阶段 的 顺序 。 


网 页 请 求 


此 


开始 阶段 { 设置 Request 、Response 和 IsPostBack 属 件 
初始 化 阶段 网 页 初始 化 


从 缓存 获取 网 页 


加 载 状态 、 处 理 传递 数据 


十 


加 载 阶段 预 加 吉 
1 
加 载 : 创建 子 控件 、 设 置 属性 
验证 阶段 { 合法 性 验证 


处 理 传递 数据 
EN sa 


回 传 事件 处 理 
执行 控件 事件 


网 页 加 载 完成 
T 

呈现 阶段 呈现 网 页 
ff 

季 才 阶段 外 教 网 页 


图 5.28 ASP.NET 网 页 的 生命 周期 


在 第 一 次 加 载 网 页 时 ,生命 周期 由 以 下 几 个 部 分 组 成 ， 

@ 浏览 器 将 对 网 页 的 请 求 发 送 到 Web 服务 器 上 ,ASP.NET 引擎 首先 要 确定 这 个 网 页 是 
和 否 已 经 存在 于 缓存 (专门 用 于 保存 最 近 使 用 过 的 对 象 的 一 部 分 内 存 空间 ) 中 。 如 果 缓 存 中 存在 
这 个 网 页 ,Web 服务 器 就 会 取得 这 个 网 页 并 返回 到 浏览 器 上 ,本 次 任务 就 完成 了 ; 如 果 缓 存 中 
不 存在 这 个 网 页 ,这 个 时 候 才 真正 开始 网 页 的 生命 周期 。 

@ 在 开始 阶段 , 回 传 模式 就 已 经 确定 了 。 如 果 这 个 网 页 是 另 一 个 网 页 发 出 的 请 求 ,那么 
它 不 是 一 个 回 传 (IsPostBack 置 为 False); 如 果 这 个 网 页 是 返回 到 Web 服务 器 进行 处 理 和 重 
新 显示 的 ,那么 它 才 是 一 个 回 传 (IsPostBack 置 为 True) 。 对 IsPostBack 和 PreviousPage 属 
性 进行 相应 的 设置 ,同时 也 要 设置 网 页 的 Request 和 Response 属性 。 

@ 在 网 页 初始 化 阶段 包含 了 两 个 通常 要 处 理 的 事件 , 即 PreInit 和 Init 事件 。 如 果 没 有 
编写 相应 的 事件 处 理 程序 代码 ,ASP.NET 会 执行 事件 的 默认 行为 。 在 PreInit 事件 中 , 先 在 
网 页 初始 化 之 前 确定 目标 设备 的 类 型 .设置 母 版 页 、 创 建 控件 树 以 及 给 控件 分 配 唯 一 的 ID, 这 
些 ID 都 已 经 在 代码 中 规定 好 了 。 在 这 个 阶段 ,还 会 在 网 页 中 加 载 和 应 用 用 户 个 性 化 设置 和 主 
题 等 。 

PreInit 是 生命 周期 中 的 第 一 个 能 被 拦截 和 处 理 的 事件 ,这 就 意味 着 它 是 第 一 个 可 以 编码 
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的 事件 ,可 以 通过 编写 代码 来 更 改 初始 化 网 页 的 默认 行为 。 在 Init 事件 中 ,将 会 读 取 或 初始 化 
控件 的 属性 。 如 果 这 是 一 个 回 传 ,那么 存储 在 视图 状态 (视图 状态 指 网 页 及 网 页 上 所 有 控件 的 
状态 ,而 状态 是 指 当前 用 户 的 当前 会 话 中 所 有 的 控件 和 变量 的 当前 值 ) 中 的 任何 值 现在 还 没有 
恢复 到 控件 中 。 

@ 在 加 载 事件 中 ,所 有 的 控件 属性 都 要 进行 设置 。 用 户 可 以 使 用 视图 状态 信息 ,也 可 以 
访问 网 页 的 控件 层次 系统 中 的 所 有 控件 。 通 常 在 Page_Load 方法 中 对 加 载 阶段 的 处 理 例 程 
进行 更 改 。 

@ 在 验证 阶段 会 调用 网 页 中 所 有 的 验证 控件 的 Validate 方法 ,并 设置 相应 控件 和 网 页 的 
IsValid 属性 。 

@ 在 呈现 (或 绘制 ) 阶 段 , 用 户 个 性 化 设置 .控件 及 视图 状态 都 会 保存 下 来 。 依 次 调用 网 
页 中 的 控件 以 绘制 在 浏览 器 上 ,也 就 是 将 各 个 控件 组 合 到 HTML 标记 中 ,标记 内 容 可 以 通过 
网 页 的 Response 属性 进行 访问 。 通 常 使 用 Page_PreRender 方法 来 处 理 PreRender 事件 。 在 
PreRender 事件 中 ,HTML 实际 上 已 经 生成 好 ,并 已 经 发 送 到 了 原来 请 求 的 网 页 中 ,除非 有 自 


定义 的 用 户 控 件 。 

@ 务 载 阶段 是 生命 周期 中 的 最 后 一 个 阶段 ， 
Unload 事件 可 以 处 理 任 何 最 后 的 扫尾 工作 ,如 关闭 文 
件 、 释 放 数据 库 连 接 等 。 

在 回 传 过 程 中 ,生命 周期 与 第 一 次 加 载 网 页 的 过 程 
相似 ,但 有 以 下 几 点 不 同 : 

@ 在 加 载 阶段 ,在 完成 网 页 初始 化 之 后 会 根据 需要 
加 载 和 应 用 视图 状态 。 

@ 在 验证 阶段 完成 后 , 回 传 的 数据 已 经 经 过 处 理 ， 
这 个 时 候 才 执行 控件 的 事件 处 理 程序 。 这 是 很 重要 的 ， 
只 有 在 网 页 初始 化 完成 ,Load 事件 已 经 处 理 完 毕 之 后 
才 会 调用 控件 的 事件 处 理 程 序 ( 如 命令 按钮 的 Click 事 
件 )。 之 所 以 重要 是 因为 各 种 事件 处 理 程序 的 执行 顺序 
对 程序 处 理 逻 辑 来 说 是 十 分 关键 的 。 


5.11.3 网 页 生命 周期 中 的 事件 


在 生命 周期 的 每 个 阶段 都 提供 了 可 以 使 用 的 方法 
和 事件 , 供 程序 开发 人 员 来 重 写 ASP.NET 引擎 的 默认 
处 理 行为 ,或 增加 自己 的 程序 处 理 逻 辑 。 

网 页 生命 周期 中 的 事件 如 图 5. 29 所 示 。 从 中 看 
到 ,尽管 Web 应 用 程序 模型 和 传统 的 桌面 应 用 程序 模 
型 有 较 大 的 不 同 ,但 它 通 过 各 种 事件 和 方法 提供 了 极 大 
的 编程 灵活 性 ,掌握 网 页 生命 周期 以 及 事件 ,就 可 以 编 
写 类 似 于 桌面 应 用 程序 那样 具有 很 强 交 互 性 的 Web 应 
用 程序 。 总 之 ,深入 理解 ASP. NET 网 页 框架 理论 对 于 
开发 复杂 的 Web 应 用 程序 是 十 分 必要 的 。 


Prelnit 事 件 
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初始 化 主题 ， 应 用 母 版 页 和 皮肤 
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Init 事 件 
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InitComplete 事 件 


1 
如 果 是 回 传 ， 则 创建 子 控件 并 加 载 状态 
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PreLoad 事 件 
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Load 事 件 


1 
如 果 是 回 传 ， 则 触发 服务 器 事件 


T 


LoadComplete 事 件 


如 果 不 是 回 传 ， 则 创建 子 控件 


PreRender 事 件 


PreRenderComplete 事 件 
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保存 控件 /视图 状态 


SaveStatusComplete 事 件 


呈现 事件 


图 5.29 网 页 生命 周期 中 的 事件 


1 
Unload 事 件 
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练习 题 5 


1. 简 述 ASP.NET 网 页 的 处 理 过 程 。 

2. 简 述 Page 对 象 的 IsPostBack 属性 和 IsValid 属性 的 含义 ,分 别 说 明 Page 对 象 的 Init 
事件 ,Load 事件 和 Unload 事件 何 时 发 生 。 

3. 简 述 Response 对 象 的 作用 。 

4. 简 述 Request 对 象 的 作用 。 

5. 简 述 使 用 Response. Redirect 方法 ,Server. Transfer 方法 和 Server. Execute 方法 实现 
网 页 转向 上 的 差异 。 

6. 简 述 使 用 Application 对 象 和 Session 对 象 保存 用 户 信息 上 的 差异 。 

7. 简 述 Cookie 对 象 的 作用 。 

8. 简 述 ViewState 对 象 的 作用 。 

9. 简 述 Global. asax 文件 的 作用 。 

10. 简 述 网 页 的 生命 周期 。 

11. 简 述 网 页 生命 周期 中 的 主要 事件 。 


上 机 实验 题 5 
在 ch5 网 站 中 添加 一 个 名 称 为 Experment5 的 网 页 ,用 于 输入 学 生 的 学 号 、 姓 名 ,性 别 和 


班 号 , 均 采 用 文本 框 接 受用 户 输入 。 当 用 户 单 击 “ 确 定 ” 命 令 按 钮 时 在 男 一 个 网 页 
Experment5-1 中 显示 该 学 生 信息 ,如 图 5. 30 所 示 。 


图 5.30 上 机 实验 题 5 网 页 的 运行 界面 


155 


第 6 章 Web 标准 服务 器 控件 


Web 标准 服务 器 控件 (简称 Web 标准 控件 ) 是 开发 网 页 中 最 常用 的 控件 。 
所 谓 控 件 是 指 一 个 可 重用 的 组 件 或 对 象 ,有 自己 的 属性 .方法 和 可 以 响应 的 事 
件 。 本 章 介 绍 这 类 Web 标准 控件 的 使 用 方法 。 

本 章 学 习 要 点 : 

加 掌握 Web 标准 控件 的 特点 和 分 类 。 

回 掌 握 各 种 表单 控件 的 使 用 方法 。 

回 掌 握 各 种 列表 控件 的 使 用 方法 。 

回 掌 握 其 他 常用 标准 控件 的 使 用 方法 。 

回 灵活 使 用 各 种 Web 标准 控件 实现 复杂 网 页 的 设计 。 


6.1 Web 标准 控件 概述 


6.1.1 Web 标准 控件 的 分 类 


Web 标准 控件 位 于 工具 箱 的 4 标准 类 别 下 ,共有 29 个 。Web 标准 控件 按 
照 功能 大 致 分 为 3 类 , 即 Web 表单 控件 .列表 控件 和 其 他 控件 ,如 图 6. 1 所 示 。 

实际 上 ,所 有 的 网 页 控件 都 是 从 System. Web. UI. Control. WebControls 
直接 或 间接 派生 而 来 的 ,都 包含 在 System. Web. UI. WebControls 命名 空间 下 ， 
所 以 ,网 页 程序 代码 都 包含 以 下 语句 引用 该 命名 空间 : 


using System. Web. UI. WebControls; 


6.1.2 Web 标准 控件 的 公共 属性 、 方 法 和 事件 


1. Web 标准 控件 的 公共 属性 
Web 标准 控件 的 属性 可 以 通过 属性 窗口 来 设置 ,也 可 以 通过 HTML 代码 
实现 ,例如 ,设置 Label 控件 的 属性 代码 如 下 : 


<asp:Label ID = "Labell" runat = "server" Font 一 Bold= "True" 
Font - Size= "Small"” Text = "一 个 标签 " Width= "80px"></asp:Label> 
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Web 标 准 控件 

Web 表 单 控件 列表 控件 其 他 控件 
Button BulletedList AdRotator 
Calendar CheckBoxList FileUpload 
CheckBox DropDownList Literal 
HiddenField ListBox Localize 
HyperLink RadioButtonList MultiView 
RadioButton PlaceHolder 
Image Substitution 


lmageButton View 
ImageMap Wizard 
Label XML 
LinkButton 
Panel 
Table 


图 6.1 Web 标准 控件 的 分 类 


Web 标准 控件 以 "asp: "为 前 级 ,ID 属性 指定 其 ID 值 ,作为 控件 的 唯一 标识 ,在 向 客户 端 
呈现 时 ,会 将 ID 属性 转换 为 id 属性 。 每 个 Web 标准 服务 器 控件 都 有 一 系列 的 属性 , 它 的 公 
共 属 性 如 下 : 

(1) AccessKey 属性 

该 属性 可 以 用 来 指定 键盘 的 快速 键 。 当 使 用 者 按 下 键盘 上 的 Alt 再 加 上 所 指定 的 值 时 ， 
表示 选择 该 控件 。 

(2) BackColor 属性 

该 属性 设 定 对 象 的 背景 色 ,其 属性 的 设 定 值 为 颜色 名 称 或 是 #RRGGBB 的 格式 。 

(3) BorderWidth 属性 

该 属性 可 以 设 定 控件 的 边框 宽度 。 

(4) BorderColor 属性 

该 属性 可 以 用 来 设 定 边框 的 颜色 。 

(5) BorderStyle 属性 

该 属性 可 以 用 来 设 定 控 件 的 边框 样式 ,共有 下 面 10 种 设 定 。 

。 NotSet: 未 设置 边框 样式 。 

。 None: 无 边框 。 

Dotted: 虚线 边框 。 

。 Dashed: 点 划 线 边框 。 

。 Solid: 实 线 边 框 。 

。 Double: 双 实 线 边框 。 

。 Groove: 用 于 凹陷 边框 外 观 的 止 槽 状 边框 。 
。 Ridge: 用 于 凸 起 边框 外 观 的 突起 边框 。 

。 Inset: 用 于 凹陷 控件 外 观 的 内 内 边 框 。 

。 Outset: 用 于 凸 起 控件 外 观 的 外 嵌 边 框 。 
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(6) Enabled 属性 

该 属性 用 来 决定 控件 是 否 正常 工作 , 即 是 否 有 效 , 默 认 值 是 True。 

(7) Font 属性 

该 属性 用 于 设置 控件 的 字体 及 大 小 ,包括 以 下 8 个 子 属性 用 来 设 定 字 型 的 样式 。 

。 FontInfo. Bold 属性 : 获取 或 设置 一 个 值 , 该 值 指示 字体 是 否 为 粗 体 。 

。 FontInfo. Italic 属性 : 获取 或 设置 一 个 值 , 该 值 指示 字体 是 否 为 斜体 。 

。 FontInfo. Name 属性 : 获取 或 设置 主要 字体 名 称 。 

。 FontInfo. Names 属性 : 获取 或 设置 字体 名 称 序列 , 按 希 望 的 顺序 排列 。 

。 FontInfo. Size 属性 : 获取 或 设置 字体 大 小 。 

。 FontInfo. Overline 属性 : 获取 或 设置 一 个 值 , 该 值 指示 字体 是 否 带 上 划 线 。 

。 FontInfo. Strikeout 属性 : 获取 或 设置 一 个 值 , 该 值 指示 字体 是 否 带 删 除 线 。 

。 FontInfo. Underline 属性 : 获取 或 设置 一 个 值 , 该 值 指示 字体 是 否 带 下 划 线 。 

(8) Height 属性 、Width 属性 

这 两 个 属性 用 来 设 定 控 件 的 高 和 宽 , 通 常 单位 是 pixel( 像 素 ,简写 为 px)。 

(9) TabIndex 属性 

该 属性 用 来 设 定 当 用 户 按 下 Tab 键 时 控件 接收 焦点 的 顺序 ,如 果 没 有 设 定 这 个 属性 ,其 
默认 值 为 零 。 如 果 控 件 的 TabIndex 属性 值 相同 , 则 是 以 控件 在 ASP.NET 网 页 中 被 配置 的 
顺序 来 决定 。 

(10) ToolTip 属性 

该 属性 用 来 设 定 小 提示 。 在 设 定 本 属性 后 , 当 用 户 停留 在 控件 上 时 就 会 出 现 提 示 的 文字 。 

(11) Visible 属性 

该 属性 决定 控件 是 否 显 示 , 当 设 定 为 False 时 ,在 运行 网 页 时 看 不 到 该 控件 。 

(12) CssClas 属性 

该 属性 用 来 获取 或 设置 由 Web 服务 器 控件 在 客户 端 呈 现 的 级 联 样式 表 (CSS) 类 , 即 设置 
控件 的 样式 。 

(13) SkinID 属性 

该 属性 获取 或 设置 要 应 用 于 控件 的 外 观 。 

(14) ViewStateMode 属性 

该 属性 获取 或 设置 此 控件 的 视图 状态 模式 , 取 值 为 Disabled 表示 禁用 此 控件 的 视图 状 
态 ,即使 父 控件 已 启用 了 视图 状态 也 是 如 此 ; 取 值 为 Enabled 表示 启用 此 控件 的 视图 状态 , 即 
使 父 控件 已 禁用 了 视图 状态 也 是 如 此 ; 取 值 为 Inherit( 默 认 值 ) 表 示 从 父 控 件 继承 
ViewStateMode 的 值 。 

2. Web 标准 控件 的 公共 方法 

Web 标准 控件 的 公共 方法 如 下 : 

(1) ApplyStyleSheetSkin 方法 

该 方法 将 网 页 样式 表 中 定义 的 样式 属性 应 用 到 控件 。 

(2) DataBind 方法 

该 方法 将 数据 源 绑 定 到 被 调用 的 服务 器 控件 及 其 所 有 子 控件 。 

(3) Dispose 方法 

该 方法 使 服务 器 控件 得 以 在 从 内 存 中 释放 之 前 执行 最 后 的 清理 操作 。 
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(4) FindControl 方法 

该 方法 在 当前 的 命名 容器 中 搜索 指定 的 服务 器 控件 。 

(5) Focus 方法 

该 方法 为 控件 设置 输入 焦点 。 

(6) GetType 方法 

该 方法 获取 当前 实例 的 类 型 。 

(7) HasControls 方法 

该 方法 确定 服务 器 控件 是 否 包含 任何 子 控件 。 

(8) Render 方法 

该 方法 将 控件 呈现 给 指定 的 HTML 编写 器 。 

(9) RenderControl 方法 

该 方法 生成 服务 器 控件 HTML 输出 。 

(10) ResolveClientUrl 方法 

该 方法 获取 浏览 器 可 以 使 用 的 URL。 

(11) ResolveUrl 方法 

该 方法 将 URL 转换 为 在 请 求 客户 端 可 用 的 URL。 

3. Web 标准 控件 的 公共 事件 

Web 标准 控件 的 公共 事件 如 下 : 

(1) DataBinding 事件 

该 事件 当 服务 器 控件 绑 定 到 数据 源 时 发 生 。 

(2) Disposed 事件 

该 事件 当 从 内 存 释放 服务 器 控件 时 发 生 , 这 是 请 求 ASP.NET 网 页 时 服务 器 控件 生存 期 
的 最 后 阶段 。 

(3) Init 事件 

该 事件 当 服务 器 控件 初始 化 时 发 生 。 初 始 化 是 控件 生存 期 的 第 一 步 。 

(4) Load 事件 

该 事件 当 服 务 器 控件 加 载 网 页 时 发 生 。 

(5) PreRender 事件 

该 事件 在 加 载 控件 对 象 之 后 .呈现 之 前 发 生 。 

(6) Unload 事件 

该 事件 当 服 务 器 控件 从 内 存 中 印 载 时 发 生 。 


6.1.3 Web 标准 控件 的 相关 操作 


1. 向 网 页 中 添加 Web 标准 控件 

通常 有 3 种 向 网 页 中 添加 Web 标准 控件 的 方法 。 

(1) 双击 实现 添加 控件 

在 网 页 上 把 光标 停留 在 要 添加 控件 的 位 置 上 ,在 工具 箱 中 双击 要 添加 的 控件 图 标 , Web 
标准 控件 就 会 呈现 在 网 页 上 光标 停留 的 位 置 。 

(2) 拖 放 实现 添加 控件 

在 工具 箱 中 找到 要 添加 的 控件 ,然后 拖 放 到 网 页 中 。 
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(3) 使 用 代码 添加 控件 

在 网 页 源 视图 代码 中 通过 输入 相应 的 代码 来 添加 控件 。 

2. 网 页 控件 的 布局 

设计 Web 窗 体 不 像 设 计 普 通 Windows 窗 体 那 样 可 以 随意 布局 控件 ,有 了 时 设计 时 对 齐 的 
控件 在 浏览 器 中 显示 时 却 不 能 对 齐 , 这 需要 进行 控件 布局 设计 ,常用 的 方法 有 以 下 两 种 。 

(1) 插入 表 实 现 网 页 控件 的 布局 

其 操作 是 选择 “ 表 | 插 入 表 ” 命 令 , 在 网 页 中 插入 一 个 合适 的 表 , 再 在 表 的 单元 格 中 添加 相 
应 的 控件 。 通 过 “ 表 | 修 改 ” 菜 单 可 以 对 表格 中 的 单元 格 进行 布局 ,包括 合并 单元 格 、 拆 分 单元 

(2) 插入 层 实现 网 页 控件 的 布局 

其 操作 是 进入 网 页 的 源 视图 ,添加 二 div 二 元 素 ,在 其 中 拖 放 控件 ,选择 “格式 | 位 置 ”命令 ， 
在 出 现 的 “定位 ”对 话 框 中 选择 “相对 ”定位 样式 ,然后 拖 动 该 层 到 合适 的 位 置 。 

3. 删除 Web 标准 控件 

删除 Web 标准 控件 有 两 种 方法 : 一 种 方法 是 选中 要 删除 的 控件 , 按 Delete 键 ; 另 一 种 方 
法 是 选中 要 删除 的 控件 ,然后 右 击 ,在 弹出 的 快捷 菜单 中 选择 “删除 ”命令 。 

4. 动态 生成 控件 和 动态 删除 控件 

每 个 控件 都 对 应 一 个 类 ,将 控件 放置 到 网 页 中 就 是 生成 该 类 的 一 个 对 象 。 其 基本 步骤 
如 下 : 

(1) 创建 控件 的 实例 并 设置 其 属性 

例如 ,标签 控件 对 应 的 类 为 Label, 可 以 用 以 下 语句 创建 一 个 标签 labell; 

Label labell = new Label(); 

labell. Text = "一 个 标签 "; 

控件 通常 在 网 页 的 初始 化 阶段 添加 到 页 面 中 ,所 以 上 述 语句 通常 放 在 网 页 的 Page_Load 
事件 过 程 中 。 

(2) 将 新 控件 添加 到 网 页 上 已 有 容器 的 Controls 集合 中 

例如 ,将 前 面 创建 的 标签 labell 放 在 网 页 中 的 语句 如 下 ， 

Page. Controls. Add( labell1); 

其 中 ,Page 网 页 对 象 作为 容器 可 以 放置 多 个 控件 ,其 Controls 属性 是 一 个 控件 对 象 集合 ， 
保存 网 页 中 的 所 有 控件 对 象 。 用 户 既 可 以 用 Add 方法 向 其 中 添加 控件 ,也 可 以 用 Clear 等 方 
法 删除 其 中 的 控件 。 例 如 ,以 下 语句 用 于 动态 删除 网 页 上 的 所 有 控件 对 象 : 

Page. Controls. Clear( ); 

说 明 : 因为 Controls 属性 是 一 个 集合 ,最 好 使 用 AddAt 方法 在 特定 位 置 放置 新 控件 , 例 
如 在 其 他 控件 的 前 面 。 

除 Page 对 象 之 外 ,容器 控件 如 Panel 也 可 以 采用 上 述 方法 动态 生成 和 删除 。 


6.2 常用 的 表单 控件 


表单 控件 放置 在 表单 中 ,构成 表单 的 基本 元 素 。 本 节 介 绍 几 个 常用 表单 控件 的 使 用 方法 。 
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6.2.1 Label 控件 


Label 控件 又 称 为 标签 控件 ,在 工具 箱 中 的 图 标 为 入 ”Label ,对 应 命名 空间 System. 
Web. UI. WebControls 中 的 Label 类 。Label 控件 用 于 显示 文本 信息 ,其 主要 的 属性 是 Text， 
用 于 设置 或 获取 该 控件 的 显示 文本 。 

注意 ; 如 果 只 想 显示 静态 文本 ,可 以 使 用 HTML 标记 进行 显示 (在 设计 时 直接 在 网 页 中 
输入 文本 ), 并 不 需要 使 用 Label 控件 , 仅 当 需 要 在 服务 器 代码 中 更 改 文本 的 内 容 或 其 他 特性 
时 才 使 用 Label 控件 。 


6.2.2 TextBox 控件 


TextBox 控件 又 称 文本 框 控件 ,在 工具 箱 中 的 图 标 为 国 TextBox ,对 应 命名 空间 
System. Web. UI. WebControls 中 的 TextBox 类 。TextBox 控件 用 于 让 用 户 输入 文本 数据 ， 
它 的 常用 属性 、 方 法 和 事件 如 表 6. 1 所 示 。 


表 6.1 TextBox 控件 的 常用 属性 、 方 法 和 事件 


类 型 名 称 说 明 
ee 获取 或 设置 一 个 值 ,该 值 表示 控件 失去 焦点 时 是 否 发 生 自 动 回 发 到 服务 器 的 
操作 
Columns 设置 文本 框 的 水 平 尺 寸 , 单 位 为 字符 
MaxLength 设置 文本 框 的 最 大 字符 数 (不 能 用 于 多 行文 本 框 ? 
高 性 ReadOnly 设置 文本 框 是 否 为 只 读 的 
Rows 设置 文本 框 的 垂直 尺寸 
Text 设置 文本 框 中 显示 的 文本 


设置 文本 框 的 文本 模式 ,可 取 MultiLine( 多 行 ) Password( 作 为 密码 输入 ) 或 
SingleLine( 单 行 ) 等 值 

Wrap 设置 多 行文 本 框 中 的 文本 是 否 回 绕 

方法 | OnTextChanged | 引发 TextChanged 事件 

事件 | TextChanged 当 文本 框 内 容 发 生 改 变 时 引发 此 事件 


TextMode 


默认 情况 下 ,TextMode 属性 设置 为 SingleLine, 它 创建 只 包含 一 行 的 文本 框 ,还 可 将 此 属 
性 设置 为 MultiLine 或 Password, 分 别 用 于 多 行文 本 输入 和 密码 输入 。 

文本 框 的 显示 宽度 由 其 Columns 属性 确定 。 如 果 文 本 框 是 多 行文 本 框 , 则 显示 高 度 由 
Rows 属性 确定 。 

使 用 Text 属性 确定 TextBox 控件 的 内 容 ,通过 设置 MaxLength 属性 可 以 限制 可 输入 到 
此 控件 中 的 字符 数 .将 Wrap 属性 设置 为 True 来 指定 当 到 达 文 本 框 的 结尾 时 单元 格 内 容 应 自 
动 在 下 一 行 继续 。 

AutoPostBack 属性 决定 控件 中 的 文本 内 容 修 改 后 是 否 自动 回 发 到 服务 器 ,默认 为 False， 
即 修改 文本 后 并 不 立即 回 发 到 服务 器 ,而 是 等 网 页 被 提交 后 一 并 处 理 。 若 为 True, 则 每 次 更 
改 文 本 框 的 内 容 并 且 焦 点 离开 控件 时 都 会 自动 回 发 ,使 服务 器 处 理 控件 相应 的 TextChanged 
舌 件 。 
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6.2.3 Button 控件 


Button 控件 又 称 命令 按钮 控件 ,在 工具 箱 中 的 图 标 为 国 Button ,对 应 命名 空间 System. 
Web. UI. WebControls 中 的 Button 类 。Button 控件 用 于 在 网 页 上 显示 下 压 按钮 , 它 的 常用 属 
性 \ 方 法 和 事件 如 表 6. 2 所 示 。 

表 6.2 Button 控件 的 常用 属性 .方法 和 事件 


类 型 名 称 说 明 
Text 设置 命令 按钮 上 显示 的 文本 

加入 CommandName 单 击 命令 按钮 时 该 值 来 指定 一 个 命令 名 称 
CommandArgument 单 击 命令 按钮 时 将 该 值 传递 给 Command 事件 
CausesValidation 设置 为 False, 则 所 提交 作为 参数 的 表单 不 被 检验 。 默 认为 True 
OnClick 引发 Click 事件 

方法 OnCommand 引发 Command 事件 

事件 Click 单 击 命令 按钮 且 包 含 它 的 表单 被 提交 到 服务 器 时 引发 此 事件 
Command 单 击 命令 按钮 时 引发 此 事件 


默认 的 Button 按钮 为 Submit( 提 交 ) 按 钮 ,在 这 种 情况 下 不 要 指定 CommandName 属性 
和 CommandArgument 属性 值 ,其 功能 是 在 单 击 时 激活 Click 事件 将 包含 它 的 表单 提交 给 相 
应 的 服务 器 进行 处 理 。 

当 设置 了 CommandName 属性 和 CommandArgument 属性 后 ,Button 按钮 成 为 Command( 命 
令 ) 按 钮 ,在 单 击 时 激活 Command 事件 。 当 多 个 Command 按钮 共用 一 个 OnCommand 方法 
时 ,可 以 根据 CommandArgument 值 确 定单 击 了 哪个 Button 控件 。 对 于 Command 按钮 ,在 
单 击 时 激活 Command 事件 ,同样 会 将 包含 它 的 表单 提交 给 相应 的 服务 器 进行 处 理 。 

【 例 6.1】 在 D 盘 ASP.NET 目录 中 建立 一 个 ch6 的 子 目录 ,将 其 作为 网 站 目录 ,然后 创 
建 一 个 WebForml 网 页 ,其 功能 是 说 明 Submit 和 Command 按钮 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012 。 

@ 选择 “文件 | 新 建 | 网 站 ”命令 ,出现 “新 建 网 站 "对话 框 ,然后 选择 “ASP.NET 空 网 站 ” 
模板 ,选择 "Web 位 置 " 为 “文件 系统 ”, 单 击 “ 浏 览 ” 按 钮 ,选择 “D:\ASP.NET\ch6” 目 录 , 单 击 
“确定 ”按钮 ,创建 一 个 空 的 网 站 ch6 。 

@ 选择 “网 站 | 添加 新 项 "命令, 出现 “添加 新 项 -ch6” 对 话 框 ,在 中 间 列 表 中 选择 "Web 窗 
体 页 ”, 将 文件 名 称 改 为 WebForml. aspx， 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 。 

@ 进入 设计 视图 ,设计 本 网 页 界面 如 图 6. 2 所 示 , 其 中 有 3 个 命令 按钮 和 一 个 标签 La- 
bell 。Buttonl 控件 的 Text 属性 设 为 “命令 按 
钮 1”, CommandName 属性 设 为 Commad， WebFormlaspxcs 
CommandArgument 属性 设 为 “命令 按钮 1”; | 命令 接生 1 可 命令 按钮 2 | 命令 按钮 3 | | 
Button2 控件 的 Text 属性 设 为 “命令 按钮 2”， [Label1] 
CommandName 属性 设 为 Commad, Comman- 
dArgument 属性 设 为 “命令 按钮 2”; Button3 mt | ws | mw | [| 加 
控件 的 Text 属性 设 为 “命令 按钮 3”。 在 该 网 
页 上 设计 如 下 事件 过 程 : 图 6.2 WebForml 网 页 设计 界面 


4 ww | 
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protected void Button_Command(object sender, CommandEventArgs e) 
Labell. Text = " 单 击 的 是 ”+ e. CommandArgument. ToString(); 
ed void Button3_Click(object sender, EventArgs e) 
{ 

Labell. Text =" 单 击 的 是 命令 按钮 3"; 
} 


进入 Buttonl 的 属性 窗口 , 单 击 多 按钮 ,设置 其 Command 事件 处 理 过 程 为 Button _ 
Command, 如 图 6. 3 所 示 。 让 Button2 也 共享 Command 事件 ,采用 同样 的 操作 设置 Button2 
的 Command 事件 处 理 过 程 为 Button_Command。 
@ 进入 网 页 的 源 视图 ,用 户 看 到 3 个 命令 按钮 对 应 的 代码 如 下 ( 粗 体 部 分 展示 了 它们 的 
不 同 点 ): 
<asp:Button ID = "Button1”runat = "server”CommandArgument = "命令 按钮 1" 
CommandName = "Command" CssClass= "auto- stylel" OnCommand = "Button Command" 
Text = "命令 按钮 1" /> 
<asp:Button ID = "Button2" runat = "server”CommandArgument = "命令 按钮 2" 
CommandName = "Command" CssClass= "auto- stylel" OnCommand = "Button Command" 
Text = "命令 按钮 2" /> 
<asp:Button ID = "Button3" runat = "server" CssClass = "auto— stylel" 
OnClick = "Button3_Click" Text = "命令 按钮 3" /> 
@ 单 击 工 具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 ,然后 单 击 “ 命 令 按 钮 2” 命令 按钮 ,其 
运行 结果 如 图 6.4 所 示 , 单 击 其 他 命令 按钮 的 运行 结果 与 此 相似 。 需 要 注意 的 是 ,Buttonl 和 
Button2 执行 的 是 Command 事件 ,而 Button3 执行 的 是 Click 事件 。 


Buttonl System.Web.ULWebControls.Button ~ 


NX 


ti 
© @ htp//iocalhost5652 PD - © | ty YY 
@ localhost x 


命令 按钮 1 || 命令 按钮 2 || 命令 按钮 3 | 


单 击 的 是 命令 按钮 2 


图 6.3 设置 Buttonl 的 Command 事件 处 理 过 程 图 6.4 WebForml 网 页 运行 界面 


6.2.4 LinkButton 控件 


LinkButton 控件 又 称 超 链接 按钮 控件 ,在 工具 箱 中 的 图 标 为 国 LinkButton ,对 应 命名 空 
间 System. Web. UI. WebControls 中 的 LinkButton 类 。LinkButton 控件 在 功能 上 与 Button 
控件 相似 ,只 是 在 呈现 的 样式 上 不 同 ,LinkButton 控件 以 超 链 接 的 形式 显示 , 它 的 常用 属性 和 
事件 如 表 6. 3 所 示 。 

和 Button 控件 一 样 ,在 不 设置 CommandName 属性 和 CommandArgument 属性 值 时 ， 
LinkButton 控件 为 提交 超 链接 按钮 ; 当 设 置 CommandName 属性 和 CommandArgument 属 
性 值 时 ,LinkButton 控件 为 命令 超 链 接 按钮 。 
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表 6.3 LinkButton 控件 的 常用 属性 和 事件 
类 型 名 称 说 明 
获取 或 设置 与 关联 的 CommandName 属性 一 起 传递 到 Command 事件 处 理 
程序 的 可 选 参数 


获取 或 设置 与 LinkButton 控件 关联 的 命令 名 ,此 值 与 CommandArgument 
属性 一 起 传递 到 Command 事件 处 理 程序 


CommandArgument 


属性 | CommandName 


PostBackUrl 获取 或 设置 单 击 LinkButton 控件 时 从 当前 页 发 送 到 的 网 页 的 URL 
Text 获取 或 设置 显示 在 LinkButton 控件 上 的 文本 标题 

| Click 在 单 击 LinkButton 控件 时 发 生 

Command 在 单 击 LinkButton 控件 时 发 生 


用 户 可 以 通过 设置 Text 属性 或 将 文本 放 在 LinkButton 控件 的 开始 和 结束 标记 之 间 来 指 
定 要 在 LinkButton 控件 中 显示 的 文本 。 
6.2.5 ”Image 控件 


Image 控件 又 称 图 像 控 件 ,在 工具 箱 中 的 图 标 为 国 image ,对 应 命名 空间 System. Web. 
UI. WebControls 中 的 Image 类 。Image 控件 用 于 在 网 页 上 显示 图 像 , 它 的 常用 属性 如 表 6. 4 
所 示 。 


表 6.4 Image 控件 的 常用 属性 


属 性 说 明 
AlternateText 获取 或 设置 当 图 像 不 可 用 时 Image 控件 中 显示 的 蔡 换文 本 
ImageAlign 获取 或 设置 Image 控件 相对 于 网 页 上 其 他 元 素 的 对 齐 方式 
ImageUrl 获取 或 设置 在 Image 控件 中 显示 的 图 像 的 位 置 


ImageUrl 属性 用 来 获取 Image 控件 中 要 显示 的 图 像 的 地 址 ,在 通过 属性 窗口 设置 该 属性 
时 , 单 击 ImageUrl 属性 后 的 贺 按 钮 ,将 弹出 一 个 "选择 图 像 "对 话 框 ,可 以 从 中 选择 要 显示 的 
图 像 。 


6.2.6 ImageButton 控件 


ImageButton 控件 又 称 超 图 像 按 钮 控件 ,在 工具 箱 中 的 图 标 为 国 magsButtoa ,对 应 命名 空 
间 System. Web. UI. WebControls 中 的 ImageButton 类 。ImageButton 控件 用 于 显示 图 像 并 
对 图 像 上 的 鼠标 单 击 作出 响应 ,其 功能 与 Button 控件 类 似 ,但 按钮 的 外 形 更 美观 . 它 的 常用 属 
性 和 事件 如 表 6.5 所 示 。 

ImageButton 控件 最 重要 的 两 个 属性 是 ImageUrl 和 PostBackUrl。ImageUrl 属性 用 来 
获取 Image 控件 中 要 显示 的 图 像 的 地 址 ,在 通过 属性 窗口 设置 该 属性 时 , 单 击 ImageUrl 属性 
后 的 贺 按 钮 ,将 弹出 一 个 “选择 图 像 ” 对 话 框 ,可 以 从 中 选择 要 显示 的 图 像 。 

PostBackUrl 属性 用 来 设置 单 击 控件 时 链接 到 的 网 页 地 址 ,在 通过 属性 窗口 设置 该 属性 
时 , 单 击 其 后 的 圆 按 钮 ,将 弹出 一 个 * 选 择 URL” 对 话 框 ,可 以 从 中 选择 要 链接 到 的 网 页 
地 址 。 
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表 6.5 ImageButton 控件 的 常用 属性 和 事件 


类 型 名 称 说 明 
CommandArgument 获取 或 设置 一 个 提供 有 关 CommandName 属性 的 附加 信息 的 可 选 参数 
CommandName 获取 或 设置 与 ImageButton 控件 关联 的 命令 名 
属性 | ImageAlign 获取 或 设置 Image 控件 相对 于 网 页 上 其 他 元 素 的 对 齐 方式 
lmageUrl 获取 或 设置 在 Image 控件 中 显示 的 图 像 的 位 置 
PostBackUrl 单 击 按钮 时 所 发 送 到 的 URL 
王 Click 在 单 击 ImageButton 时 发 生 
Wt 在 单 击 ImageButton 时 发 生 


和 Button 控件 一 样 ,在 不 设置 CommandName 属性 和 CommandArgument 属性 值 时 ， 
ImageButton 控件 为 提交 图 像 按钮 ; 当 设 置 CommandName 属性 和 CommandArgument 属性 
值 时 ,ImageButton 控件 为 命令 图 像 按 钮 。 


6.2.7 HyperLink 控件 


HyperLink 控件 又 称 超 链 接 控件 ,在 工具 箱 中 的 图 标 为 急 Hyperink ,对 应 命名 空间 
System. Web. UI. WebControls 中 的 HyperLink 类 。HyperLink 控件 用 于 显示 到 其 他 网 页 
的 链接 ,类 似 于 HTML 的 二 a href 二 "…" 二 标记 。HyperLink 控件 的 常用 属性 如 表 6. 6 
所 示 。 


表 6.6 HyperLink 控件 的 常用 属性 


属 性 说 明 

ImageUrl 获取 或 设置 HyperLink 控件 显示 的 图 像 的 路 径 
NavigateUrl 获取 或 设置 单 击 HyperLink 控件 时 链接 到 的 URL 
Target 指定 NavigateUrl 的 目标 框架 

Text 获取 或 设置 HyperLink 控件 的 文本 标题 


HyperLink 控件 最 重要 的 两 个 属性 是 ImageUrl 和 NavigateUrl。ImageUrl 属性 用 来 获 
取 Image 控件 中 要 显示 的 图 像 的 地 址 ,在 通过 属性 窗口 设置 该 属性 时 , 单 击 ImageUrl 属性 后 
的 圆 按钮 ,将 弹出 一 个 “选择 图 像 " 对 话 框 ,可 以 从 中 选择 要 显示 的 图 像 。 

NavigateUrl 属性 用 来 设置 单 击 控件 时 链接 到 的 网 页 地 址 ,在 通过 属性 窗口 设置 该 属性 
时 , 单 击 其 后 的 国 按 钮 ,将 弹出 一 个 “选择 URL” 对 话 框 ,可 以 从 中 选择 要 链接 到 的 网 页 
地 址 。 

另外 ,Target 属性 指出 一 个 要 显示 转向 的 网 页 的 框架 或 窗口 ,其 取 值 参见 第 3 章 中 的 
表 3.5。 


6.2.8 ImageMap 控件 


ImageMap 控件 在 工具 箱 中 的 图 标 为 图 ImageMap ,对 应 命名 空间 System. Web. UI. 
WebControls 中 的 ImageMap 类 。ImageMap 控件 用 于 在 网 页 上 显示 图 像 ,在 图 像 中 可 以 指 
定 若干 作用 点 区 域 (也 称 为 热点 )。 单 击 ImageMap 控件 内 定义 的 作用 点 区 域 时 ,该 控件 生 
成 到 服务 器 的 回 发 或 导航 到 指定 的 URL。ImageMap 控件 的 常用 属性 和 事件 如 表 6. 7 
所 示 。 
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表 6.7 ImageMap 控件 的 常用 属性 和 事件 


类 型 名 称 说 明 
lmageUrl 获取 或 设置 ImageMap 控件 显示 的 图 像 的 路 径 
ImageAlign 获取 或 设置 ImageMap 控件 中 图 像 相 对 于 网 页 上 其 他 元 素 的 对 齐 方式 
属性 oid 获取 或 设置 单 击 HotSpot 对 象 时 ImageMap 控件 的 HotSpot 对 象 的 默认 行为 ,其 
取 值 及 说 明 如 表 6. 8 所 示 
HotSpots 获取 HotSpot 对 象 的 集合 ,这 些 对 象 表示 ImageMap 控件 中 定义 的 作用 点 区 域 
事件 | Click 单 击 ImageMap 控件 的 HotSpot 对 象 时 发 生 


HotSpots 属性 是 一 个 HotSpot 对 象 的 集合 ,每 个 HotSpot 对 象 指定 一 个 或 多 个 作用 点 
区 域 。HotSpot 对 象 可 以 是 以 下 3 个 类 的 对 象 。 


CircleHotSpot 类 : 该 类 在 ImageMap 控件 中 定义 一 个 圆 形 作用 点 区 域 。 若 要 定义 该 
对 象 区 域 , 需 将 X 属性 设置 为 表示 圆 形 区 域 中 心 的 xz 坐标 的 值 ,将 Y 属性 设置 为 表示 
圆 形 区 域 中 心 的 y 坐标 的 值 .将 Radius 属性 设置 为 从 圆心 到 边 的 距离 。 
RectangleHotSpot 类 : 该 类 在 ImageMap 控件 中 定义 一 个 矩形 作用 点 区 域 。 若 要 定 
义 该 对 象 的 区 域 , 需 将 Left 属性 设置 为 表示 该 矩形 区 域 左 上 角 的 x 坐标 的 值 ,将 Top 
属性 设置 为 表示 该 矩形 区 域 左上 和 角 的 y 坐标 的 值 ,将 Right 属性 设置 为 表示 该 矩形 区 
域 右 下 角 的 xz 坐标 的 值 ,将 Bottom 属性 设置 为 表示 该 矩形 区 域 右 下 角 的 y 坐标 的 值 。 
PolygonHotSpot 类 : 该 类 在 ImageMap 控件 中 定义 一 个 多 边 形 作用 点 区 域 。 当 在 
ImageMap 控件 中 定义 不 规则 形状 的 作用 点 区 域 时 ,PolygonHotSpot 对 象 很 有 用 。 例 
如 ,在 地 图 中 可 以 使 用 它 来 定义 单独 区 域 。 若 要 定义 PolygonHotSpot 区 域 , 需 将 
Coordinates 属性 设置 为 指定 PolygonHotSpot 对 象 每 个 顶点 的 坐标 的 字符 串 。 多 边 
形 顶 点 是 两 条 多 边 形 边 的 交点 。 


在 应 用 中 还 需要 为 一 个 ImageMap 控件 中 的 所 有 HotSpot 对 象 指定 HotSpotMode 属性 
(其 取 值 如 表 6. 8 所 示 )、.PostBackValue 属性 (获取 或 设置 单 击 HotSpot 时 在 事件 数据 中 传递 
的 HotSpot 对 象 名 称 ) 和 NavigateUrl( 获 取 或 设置 单 击 HotSpot 对 象 时 导航 至 的 URL)。 


表 6.8 HotSpotMode 属性 的 取 值 及 说 明 


属性 值 说 明 
Inactive HotSpot 对 象 不 具有 任何 行为 
NotSet HotSpot 对 象 使 用 由 ImageMap 控件 的 HotSpotMode 属性 设置 的 行为 ,如 果 ImageMap 


控件 未 定义 行为 ,HotSpot 对 象 将 导航 到 URL 


Navigate HotSpot 对 象 导航 到 URL 
PostBack HotSpot 对 象 生成 到 服务 器 的 回 发 


若 一 个 ImageMap 控件 中 包含 的 所 有 HotSpot 对 象 都 具有 相同 的 行为 ,可 以 使 用 
ImageMap 控件 的 HotSpotMode 属性 指定 行为 ,然后 将 每 个 HotSpot 对 象 的 HotSpotMode 


属性 都 设置 为 HotSpotMode. NotSet, 也 可 以 不 指定 HotSpot. HotSpotMode 属性 的 值 。 若 一 
个 ImageMap 控件 中 包含 的 HotSpot 对 象 具有 不 同 的 行为 , 则 必须 为 每 个 HotSpot 对 象 单独 
设置 HotSpot. HotSpotMode 属性 值 。 如 果 ImageMap 控件 和 所 包含 的 HotSpot 对 象 都 设置 
了 HotSpotMode 属性 , 则 针对 每 个 HotSpot 对 象 指 定 的 HotSpot. HotSpotMode 属性 将 优先 
于 ImageMap 控件 的 ImageMap. HotSpotMode 属性 。 
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在 属性 窗口 中 单 击 ImageMap 控件 的 HotSpots 属性 后 的 圆 按钮 ,将 弹出 一 个 "HotSpot 
集合 编辑 器 对话 框 ,可 以 添加 HotSpot 对 象 , 图 6. 5 所 示 的 是 添加 3 个 热点 ,用 户 也 可 以 通过 
网 页 的 源 视图 修改 或 添加 网 页 中 的 热点 。 


RectangleHotSpot 层 性 (P): 
国 %|# 


1|RectangleHotSpot 
2| CirceHotSpot 


图 6.5 “HotSpot 集合 编辑 器 "对话 框 


【 例 6.2】 在 ch6 网 站 中 设计 一 个 WebForm2 网 页 ,其 功能 是 说 明 ImageMap 控件 和 热 
点 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch6 网 站 ,在 解决 方案 资源 管理 器 中 右 击 “ch6” 项 目 名 ,在 出 现 的 快捷 菜单 中 选择 
“添加 | 新 建 目录 ”命令 ,添加 一 个 名 称 为 Images 的 目录 ,在 其 中 放 入 一 个 “水 果 . jpg” 的 图 像 
文件 。 

@ 选择 “网 站 | 添加 新 项 "命令 ,出 现 “ 添 加 新 项 -ch6” 对 话 框 ,在 中 间 列 表 中 选择 "Web 窗 
体 ”, 将 文件 名 称 改 为 WebForm2. aspx, 其 他 保持 默认 项 , 单 击 * 添 加 ”按钮 。 

@ 本 网 页 的 设计 界面 如 图 6. 6 所 示 , 其 中 有 一 个 ImageMap 控件 ImageMapl 和 一 个 标 
签 Labell 。 将 ImageMapl 控件 的 ImageUrl 属性 设 为 “水 果 . jpg” 图 像 ,HotSpotMode 属性 设 
为 PostBack ,并 通过 “HotSpot 集合 编辑 器 ?对话 框 设置 3 个 热点 ,分 别 对 应 3 个 水 果 的 位 置 ， 
前 两 个 多 边 形 对 应 苹果 和 草莓 图 像 ,后 一 个 圆 形 对 应 桃子 图 像 。 

@ 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void ImageMapl_Click(object sender, ImageMapEventArgs e) 


{ 
Labell. Text = "您 单 击 了 " + e.PostBackValue; 


} 
@ 进入 网 页 的 源 视图 进行 修改 ,ImageMapl 控件 对 应 的 代码 如 下 : 
<asp:ImageMap ID= "ImageMap1”runat = "server" Height = "116px" 

ImageUrl = "一 /Images/ 水 果 . jpg" OnClick = "ImageMapl_Click" Width = "307px"> 


<asp:RectangleHotSpot HotSpotMode = "PostBack" 
PostBackValue = "苹果 " Left = "0" Top = "0" Right = "100" Bottom = "110" /> 
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<asp:RectangleHotSpot HotSpotMode = "PostBack" 
PostBackValue = "草莓 " Left = "110" Top = "0" Right = "210" Bottom = "110" /> 
<asp:CircleHotSpot HotSpotMode = "PostBack” PostBackValue = "桃子 " 
Radius= "45" X= "260" Y= "65" /> 
</asp: ImageMap > 


@ 单 击 工具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 ,然后 单 击 其 中 的 圆 形 热点 ,其 结果 如 
图 6.7 所 示 , 当 鼠标 指针 移 开 热点 时 该 圆 形 会 立即 消失 。 


a lal 
WebForm2aspx* HX 吕 @S 狠 htpi//localhost55528/W D> 
上 一 一 一 一 一 一 一 ~ @ localhost x > 


eben] 


您 单 击 了 桃子 


- 
1 


» 
设计 |a 折 分 |。 源 | [4] <asp:circeHotspo [>] 


图 6.6 WebForm2 网 页 设计 界面 图 6.7 WebForm2 网 页 运行 界面 


6.2.9 Table 控件 


Table 控件 又 称 表格 控件 ,在 工具 箱 中 的 图 标 为 国 、Table ,对 应 命名 空间 System. Web. 
UI WebControls 中 的 Table 类 。Table 控件 用 于 在 网 页 上 显示 表格 ,其 常用 属性 如 表 6. 9 
所 示 。 
表 6.9 Table 控件 的 常用 属性 及 其 说 明 


属 性 说 明 
BackImageUrl 获取 或 设置 要 在 Table 控件 的 后 面 显示 的 背景 图 像 的 URL 
CellPadding 获取 或 设置 单元 格 的 内 容 和 单元 格 的 边框 之 间 的 空间 量 
CellSpacing 获取 或 设置 单元 格 间 的 空间 量 
GridLines 获取 或 设置 Table 控件 中 显示 的 网 格 线 型 
Rows 获取 Table 控件 中 行 的 集合 


在 属性 窗口 中 单 击 Table 控件 的 Rows 属性 后 的 国 按 钮 ,弹出 一 个 “TableRow 集合 编辑 
器 ?对 话 框 , 可 以 添加 行 对 象 , 如 图 6. 8 所 示 。 对 于 每 个 行 对 象 ,又 可 以 单 击 Cells 属性 后 的 国 
按钮 ,弹出 一 个 “TableCell 集合 编辑 器 "对话 框 ,以 添加 单元 格 ,如 图 6.9 所 示 。 

Table 对 象 的 Rows 属性 是 一 个 行 集合 ( 即 一 个 TableRowCollection 类 对 象 ) ,每 个 行 是 
一 个 TableRow 对 象 。 用 户 可 以 使 用 常用 的 集合 方法 操作 Table 对 象 的 Rows 属性 ,例如 ， 
Add 方法 将 指定 的 TableRow 对 象 追加 到 Rows 属性 的 结尾 处 ,Clear 方法 从 Rows 属性 中 移 
除 所 有 TableRow 对 象 ,Remove 方法 从 Rows 属性 中 移 除 指定 的 TableRow。 

TableRow 对 象 的 Cells 属性 是 一 个 单元 格 集合 ( 即 一 个 TableCellCollection 类 对 象 ) ,每 
个 单元 格 是 一 个 TableCell 对 象 。 用 户 可 以 使 用 常用 的 集合 方法 操作 TableRow 对 象 的 Cells 
属性 。 

TableCell 类 表示 Table 控件 中 的 单元 格 。 用 户 可 以 使 用 其 Text 属性 指定 或 确定 单元 格 


的 内 容 , 设 置 HorizontalAlign 和 VerticalAlign 属性 来 指定 单元 格 内 容 的 对 齐 方式 ,使 用 


Wrap 
图 
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国 %|* 


图 6.8 “TableRow 集合 编辑 器 "对话 框 


图 6.9 “TableCell 集合 编辑 器 ”对话 框 


属性 指定 单元 格 内 容 是 否 在 单元 格 内 换行 。 
6. 10 是 一 个 Table 控件 在 浏览 器 中 的 运行 结果 ,其 对 应 的 HTML 代码 如 下 : 


<asp:Table ID = "Tablel" runat = "server" BorderStyle = "Groove" BorderWidth = "lpx" 


CellPadding = "1" CellSpacing = "1" GridLines = "Both" Width= "223px"> 
<asp:TableRow runat = "server" ForeColor = "Blue" HorizontalAlign = "Center"> 
<asp:TableCell runat = "server" Font — Bold = "True" Font - Names = "楷体 " 
ForeColor = "Red"> 学 号 </asp:TableCell> 
<asp:TableCell runat = "server" Font ~ Bold = "True" Font - Names = "楷体 " 
Font — Size = "Medium"” ForeColor = " 间 FF3300"> 姓 名 </asp: TableCell > 
</asp: TableRow> 
<asp:TableRow runat = "server" ForeColor = " 井 FF5050" HorizontalAlign= "Center"> 
<asp:TableCell runat= "server" Font ~ Bold= "True" 
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Font - Names = "仿宋 "> 101 </asp:TableCell> 


<asp:TableCell runat = "server" Font ~ Bold= "True" 万 @ 
一 hrtpi//localho: ID 
Font - Names = "仿宋 "> 王 华 </asp:TableCel1> (人 G) 5 
</asp:TableRow> 展 localhost x 上 
</asp:Table> 学 号 姓名 
2 101 玉 华 


说 明 : 如 果 在 设计 网 页 时 仅仅 用 表格 就 能 进行 页 面 布 局 ， 
最 好 不 用 Table 控件 ,而 是 采用 工具 箱 中 HTML 类 别 下 的 
Table 标记 。 或 者 将 所 标 指针 移动 到 一 div 沁 区域 ,此 时 菜单 栏 
中 会 出 现 “ 表 ”菜单 项 ,从 中 选择 “插入 表 ” 命 令 插入 一 个 表 , 然 
后 通过 “格式 ”菜单 对 其 格式 化 。 
6.2.10 ”Panel 控件 

Panel 控件 在 工具 箱 中 的 图 标 为 Panel ,对 应 命名 空间 System. Web. UI. WebControls 
中 的 Panel 类 。Panel 控件 可 以 作为 其 他 控件 的 容器 ,用 于 对 控件 进行 分 组 ,以 帮助 用 户 组 织 
Web 网 页 的 内 容 。 其 常用 属性 如 表 6. 10 所 示 。 

表 6.10 ”Panel 控件 的 常用 属性 及 其 说 明 


图 6.10 一 个 Table 控件 的 
运行 结 


属 性 说 明 
BackImageUrl 获取 或 设置 面板 控件 背景 图 像 的 URL 
DefaultButton 获取 或 设置 Panel 控件 中 包含 的 默认 按钮 的 标识 符 
Direction 获取 或 设置 在 Panel 控件 中 显示 包含 文本 的 控件 的 方向 
GroupingText 获取 或 设置 面板 控件 中 包含 的 控件 组 的 标题 
ScrollBars 获取 或 设置 Panel 控件 中 滚动 条 的 可 见 性 和 位 置 


说 明 : Panel 控件 是 其 他 控件 的 容器 。 当 要 以 编程 方式 生成 控件 .隐藏 或 显示 一 组 控件 或 
本 地 化 一 组 控件 时 ,该 控件 尤其 有 用 。 


6.2.11 HiddenField 控件 


HiddenField 控件 在 工具 箱 中 的 图 标 为 品 Hiddenfield ,对 应 命名 空间 System. Web. UI. 
WebControls 中 的 HiddenField 类 。HiddenField 控件 用 于 存储 非 显 示 值 的 隐藏 字段 ,其 常用 
属性 如 表 6. 11 所 示 。 

HiddenField 控件 用 于 存储 一 个 值 , 一 般 使 用 Value 属性 来 设置 HiddenField 控件 的 值 ， 
在 向 服务 器 的 各 次 发 送 过 程 中 需 保持 该 值 , 它 呈现 为 <input type 一 “hidden"/ 盖 元 素 。 

表 6.11 HiddenField 控件 的 常用 属性 和 事件 


类 型 名 称 说 明 
属性 Value 获取 或 设置 隐藏 字段 的 值 


通常 情况 下 ,网 页 的 状态 由 视图 状态 .会话 状态 和 cookie 来 维持 。 但 是 ,如 果 这 些 方法 被 
禁用 或 不 可 用 , 则 可 以 使 用 HiddenField 控件 来 存储 状态 值 。 


6.2.12 ” Calendar 控件 
Calendar 控件 又 称 为 日 历 控件 ,在 工具 箱 中 的 图 标 为 国 calendar ,对 应 命名 空间 System. 
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Web. UI. WebControls 中 的 Calendar 类 。Calendar 控件 用 于 显示 单 月 月 历 , 该 月 历 使 用 户 可 
以 选择 日 期 并 移 到 下 个 月 或 上 个 月 。Calender 控件 的 常用 属性 和 事件 如 表 6. 12 所 示 。 


表 6. 12 Calender 控件 的 常用 属性 和 事件 


类 型 名 称 说 明 
Caption 获取 或 设置 呈现 为 日 历 标题 的 文本 值 
CaptionAlign 获取 或 设置 呈现 为 日 历 标题 的 文本 的 对 齐 方式 
CellPadding 获取 或 设置 单元 格 的 内 容 和 单元 格 的 边框 之 间 的 空间 量 
CellSpacing 获取 或 设置 单元 格 间 的 空间 量 


DayHeaderStyle “| 获取 显示 一 周 中 某 天 的 部 分 的 样式 属性 


DayNameFormat “| 获取 或 设置 周 中 各 天 的 名 称 格式 


DayStyle 获取 显示 的 月 份 中 日 期 的 样式 属性 


FirstDayOfWeek ”| 获取 或 设置 要 在 Calendar 控件 的 第 一 天 列 中 显示 的 一 周 中 的 某 天 


NextMonthText ”| 获取 或 设置 为 下 一 月 导航 控件 显示 的 文本 


PrevMonthText “| 获取 或 设置 为 前 一 月 导航 控件 显示 的 文本 


SelectedDate 获取 或 设置 选 定 的 日 期 


属性 | SelectedDates 获取 System. DateTime 对 象 的 集合 ,这 些 对 象 表示 Calendar 控件 上 的 选 定 日 期 


SelectedDayStyle “| 获取 选 定 日 期 的 样式 属性 


获取 或 设置 Calendar 控件 上 的 日 期 选择 模式 ,该 模式 指定 用 户 可 以 选择 单 日 、 
一 周 还 是 整 月 


SelectionMode 


SelectMonthText | 获取 或 设置 为 选择 器 列 中 月 份 选择 元 素 显 示 的 文本 


SelectWeekText ”| 获取 或 设置 为 选择 器 列 中 周 选择 元 素 显 示 的 文本 
ShowDayHeader ”| 获取 或 设置 一 个 值 ,该 值 指示 是 否 显示 一 周 中 各 天 的 标 头 
ShowGridLines 获取 或 设置 一 个 值 ,该 值 指示 是 否 用 网 格 线 分 隔 Calendar 控件 上 的 日 期 


TitleStyle 获取 Calendar 控件 的 标题 标 头 的 样式 属性 
TodayDayStyle 获取 Calendar 控件 上 今天 日 期 的 样式 属性 
TodaysDate 获取 或 设置 今天 的 日 期 的 值 


WeekendDayStyle | 获取 Calendar 控件 上 周末 日 期 的 样式 属性 
事件 | SelectionChanged | 当 用 户 通过 单 击 日 期 选择 器 控件 选择 一 天 、 一 周 或 整 月 时 发 生 


【 例 6.3】 在 ch6 网 站 中 设计 一 个 WebForm3 网 页 ,其 功能 是 说 明 Calender 控件 的 使 用 
方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch6 网 站 ,选择 “网 站 | 添加 新 项 "命令 ,出 现 “ 添 加 新 项 -ch6” 对 话 框 ,在 中 间 列 表 中 
选择 “Web 窗 体 ”, 将 文件 名 称 改 为 WebForm3. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 。 

@ 本 网 页 的 设计 界面 如 图 6. 11 所 示 , 其 中 有 一 个 Calender 控件 Calenderl 和 一 个 标签 
Labell。 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Calendar1_SelectionChanged(object sender, EventArgs e) 
{ ”Labell.Text = "选取 的 日 期 :"” + 

Calendar1. SelectedDate. ToLongDateString(); 
} 


@ 单 击 工 具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,选中 2015 年 4 月 20 日 ,其 结果 如 
图 6. 12 所 示 。 
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I®) 碟 hapy/localhost5652 P -~ 上 


于 日 周一 周二 周三 周 四 周 五 周 六 
29 30 31 1 2 3 4 
5 6 于 8 9 10 型 
2 

l19 20 21 22 23 24 25 
26 27 28 29 30 1 2 


可 


| [Labell] 一 
4 


选取 的 日 期 :2015 年 4 月 20 日 
设计 | 日 拆 分 |。 源 | [4] <asp:calendara|] 


图 6.11 WebForm3 网 页 设计 界面 图 6.12 WebForm3 网 页 运行 界面 


6.2.13 RadioButton 控件 


RadioButton 控件 又 称 单 选 按钮 控件 ,在 工具 箱 中 的 图 标 为 加 RadioButon ,对 应 命名 空间 
System. Web. UI. WebControls 中 的 RadioButton 类 。RadioButton 类 派生 自 CheckBox 类 ， 
允许 用 户 互 斥 地 从 多 个 RadioButton 控件 中 选择 一 个 。RadioButton 控件 的 常用 属性 和 事件 
如 表 6. 13 所 示 。 


表 6.13 RadioButton 控件 的 常用 属性 和 事件 


类 型 名 称 说 明 

AutoPostBack 获取 或 设置 一 个 值 ,该 值 指 示 在 单 击 时 RadioButton 状态 是 否 自 动 回 发 到 服务 器 
属性 Checked 获取 或 设置 一 个 值 ,该 值 指示 是 否 已 选中 RadioButton 控件 

GroupName 获取 或 设置 单 选 按钮 所 属 的 组 名 

Text 获取 或 设置 与 RadioButton 关联 的 文本 标签 
事件 | CheckedChanged | 当 Checked 属性 的 值 在 向 服务 器 进行 发 送 期 间 更 改 时 发 生 


RadioButton 控件 中 的 GroupName 是 一 个 非常 重要 的 属性 ,如 果 网 页 中 有 多 个 RadioButton 
控件 ,那些 GroupName 属性 相同 的 RadioButton 控件 在 逻辑 上 属于 一 个 组 ,所 以 对 于 属 同一 
组 的 RadioButton 控件 需 将 它们 的 GroupName 属性 设置 为 同一 值 。 

RadioButton 控件 主要 的 事件 是 CheckedChanged, 当 用 户 单 击 该 控件 时 引发 执行 对 应 的 
事件 处 理 过 程 。 

【 例 6.4】 在 ch6 网 站 中 设计 一 个 WebForm4 网 页 ,其 功能 是 说 明 RadioButton 控件 的 
使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch6 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch6” 对 话 框 ,在 中 间 列 表 中 
选择 “Web 窗 体 ”, 将 文件 名 称 改 为 WebForm4. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 。 

@ 本 网 页 的 设计 界面 如 图 6. 13 所 示 , 其 中 有 一 个 Panel 控件 Panell 、 一 个 命令 按钮 
Buttonl 和 一 个 标签 Labell。Panell 放置 4 个 RadioButton 控件 ,它们 的 ID 属性 从 上 到 下 分 
别 为 sell 一 sel4 ,将 它们 的 GroupName 属性 都 设置 为 op。 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Buttonl Click(object sender, EventArgs e) 
{ if (sel3.Checked) 
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Labell.Text = "答对 了 ,好 棒 啊 "; 


Labell. Text = " 答 错 了 ,加 油 啊 "; 


@ 单 击 工 具 栏 中 的 > internet Explorer 按钮 运行 本 网 页 ,选中 “Windows” 选 项 , 单 击 “ 确 定 ” 命 
令 按 钮 ,其 结果 如 图 6. 14 所 示 。 


[roocahorsos2 P - | WY 


愿 localhost x 


如 下 哪个 是 操作 秒 统 
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OyJava 
®@Windows 
O SQL Server 


[证 ] 


答对 了 ， 好 棒 啊 


CWindows 
© SQL Server 


| 


[Labell] 流 
4 


» 
5 设计 白 分 |。 源 | [<pauto-styeD] 


图 6.13 WebForm4 网 页 设计 界面 图 6.14 WebForm4 网 页 运行 界面 


6.2.14 CheckBox 控件 
CheckBox 控件 又 称 复 选 框 控件 ,在 工具 箱 中 的 图 标 为 国 checkBox ,对 应 命名 空间 
System. Web. UI. WebControls 中 的 CheckBox 类 。 该 控件 为 用 户 提供 了 一 种 输入 布尔 型 数 
据 的 方法 ,允许 用 户 进 行 多 项 选择 ,对 应 HTML 的 一 input type 一 "checkbox" 二 。CheckBox 
控件 的 常用 属性 和 事件 如 表 6. 14 所 示 。 
表 6.14 CheckBox 控件 的 常用 属性 和 事件 


类 型 名 称 说 明 

AutoPostBack 获取 或 设置 一 个 值 .该 值 指 示 在 单 击 时 CheckBox 状态 是 否 自动 回 发 到 服务 器 
属性 | Checked 获取 或 设置 一 个 值 .该 值 指 示 是 否 已 选中 CheckBox 控件 

Text 获取 或 设置 与 CheckBox 关联 的 文本 标签 
事件 | CheckedChanged | 当 Checked 属性 的 值 在 向 服务 器 进行 发 送 期 间 更 改 时 发 生 


【 例 6.5】 在 ch6 网 站 中 设计 一 个 WebForm5 网 页 ,其 功能 是 说 明 CheckBox 控件 的 使 


用 方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch6 网 站 ,选择 “网 站 | 添加 新 项 命令 :出现 "添加 新 项 -ch6” 对 话 框 , 在 中 间 列 表 中 
选择 “Web 窗 体 ”, 将 文件 名 称 改 为 WebForm5. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 。 

@ 本 网 页 的 设计 界面 如 图 6. 15 所 示 , 其 中 有 一 个 Panel 控件 Panell. 一 个 命令 按钮 
Buttonl 和 一 个 标签 Labell 。Panell 放置 4 个 CheckBox 控件 ,它们 的 ID 属性 从 上 到 下 分 别 
为 sell 一 sel4。 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Button1_Click(object sender, EventArgs e) 
{ if (sell.Checked && ! sel2.Checked && sel3. Checked && ! sel4.Checked) 
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Labell.Text = "答对 了 ,好 棒 啊 "; 
else 


Labell.Text =“" 答 错 了 ,加 油 啊 "; 
} 


四 单 击 工具 栏 中 的 Internet Explorer 按钮 运行 本 网 页 ,选中 第 2、3 个 选项 , 单 击 “ 确 定 ” 命 令 
按钮 ,其 结果 如 图 6. 16 所 示 。 
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图 6.15 WebForm5 网 页 设计 界面 图 6.16 WebForm5 网 页 运行 界面 


6.3 ”常用 的 列表 控件 


列表 控件 可 以 存放 多 个 数据 项 ,本 节 介 绍 几 个 常用 列表 控件 的 使 用 方法 。 
6.3.1 ”DropDownList 控件 


DropDownList 控件 又 称 下 拉 列 表 控 件 ,在 工具 箱 中 的 图 标 为 置 PrepDowntist ,对 应 命名 空 
间 System. Web. UI. WebControls 中 的 DropDownList 类 , 它 是 从 ListControl 类 派生 的 。 
ListControl 类 用 作 定 义 所 有 列表 类 型 控件 通用 的 属性 、 方 法 和 事件 的 抽象 基 类 ,所 以 所 有 的 
列表 控件 具有 许多 相同 的 特性 。 
使 用 DropDownList 控件 可 以 创建 只 允许 用 户 从 中 选择 一 项 的 下 拉 列 表 控件 , 它 的 常用 
属性 和 事件 如 表 6. 15 所 示 。 


表 6.15 DropDownList 控件 的 常用 属性 和 事件 


类 型 名 称 说 明 
AutoPostBack 该 值 指示 当 用 户 更 改 列表 中 的 选 定 内 容 时 是 否 自动 产生 向 服务 器 的 回 发 
DataMember 获取 或 设置 要 绑 定 到 控件 的 DataSource 中 的 特定 表 
DataSource 获取 或 设置 填充 列表 控件 项 的 数据 源 
属性 | DataTextField 获取 或 设置 为 列表 项 提供 文本 内 容 的 数据 源 字段 
DataValueField 获取 或 设置 为 各 列表 项 提供 值 的 数据 源 字段 
Items 获取 列表 控件 项 的 集合 
SelectedItem 获取 列表 控件 中 索引 最 小 的 选 定 项 
事件 SelectedIndexChanged | 当 列 表 控件 的 选 定 项 在 信息 发 往 服务 器 期 间 变 化 时 发 生 
TextChanged 当 Text 和 SelectedValue 属性 更 改 时 发 生 
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使 用 SelectedIndex 属性 以 编程 方式 指定 或 确定 DropDownList 控件 中 的 选 定 项 的 索引 。 
DropDownList 控件 中 总 是 选择 一 项 ,无 法 同时 取消 选择 列表 中 的 所 有 项 。DropDownList 控 
件 中 的 项 的 索引 从 零 开 始 。 

注意 : 若 要 使 DropDownList 控件 执行 SelectedIndexChanged 等 事件 处 理 过 程 ,需要 将 
该 控件 的 AutoPostBack 属性 设置 为 True( 默 认 值 为 False)。 也 就 是 说 ,只 要 用 户 从 列表 控件 
中 进行 选择 ,就 会 立即 引发 SelectedIndexChanged 事件 ,如 果 AutoPostBack 属性 为 True, 则 
每 次 选择 时 都 将 表单 发 送 到 服务 器 ,但 在 每 个 往返 行程 中 选 定 的 项 保持 不 变 。 

DropDownList 控件 的 Items 是 一 个 集合 属性 ,其 中 每 个 元 素 ( 项 ) 是 一 个 ListItem 对 象 。 
Items 是 ListItemCollection 类 的 对 象 ,而 ListItemCollection 类 的 常用 属性 和 方法 如 表 6. 16 
所 示 。 


表 6.16 ListltemCollection 类 的 常用 属性 和 事件 


类 型 名 称 说 明 
Count 获取 集合 中 的 Listltem 对 象 数 
i 获取 集合 中 指定 索引 处 的 Listhtem 
Add 将 Listltem 追加 到 集合 的 结尾 
AddRange 将 Listltem 对 象 数组 中 的 项 添加 到 集合 
Clear 从 集合 中 移 除 所 有 Listltem 对 象 
Contains 确定 集合 是 否 包含 指定 的 项 
_ FindByText 搜索 集合 中 具有 Text 属性 且 包 含 指定 文本 的 ListItem 
罗 流 FindByValue 搜索 集合 中 具有 Value 属性 且 包 含 指定 值 的 Listltem 
IndexOf 确定 索引 值 ,该 值 表示 指定 Listltem 在 集合 中 的 位 置 
Insert 将 Listltem 插入 集合 中 的 指定 索引 位 置 
Remove 从 集合 中 移 除 Listltem 
RemoveAt 从 集合 中 移 除 指定 索引 位 置 的 Listltem 


在 设计 时 设置 Items 属性 的 方法 是 单 击 DropDownListl 控件 右上 角 的 3 按钮 ， 
6.17 所 示 的 “DropDownList 任务 ”菜单 ,选择 “编辑 项 "命令 ,打开 如 图 6. 18 所 示 的 “ListItem 
集合 编辑 器 ”对 话 框 ,通过 “添加 ”按钮 增加 Items 属性 中 的 各 个 项 ,并 输入 各 项 的 Text 和 
Value 属性 值 ,这 里 添加 了 4 项 ,对 应 的 HTML 代码 如 下 : 


<asp:DropDownList ID = "DropDownList1" runat = 
"server"> 
<asp:ListItem > 打球 </asp:ListItem> 
<asp:ListItem > 跑步 </asp:ListItem> 
<asp:ListItem > 看 书 </asp:ListItem> 
<asp:ListItem> 上 网 </asp:ListItem> 
</asp:DropDownList > 


在 运行 程序 时 也 可 以 动态 地 向 DropDownList 控件 中 添加 项 。 例 如 ,以 下 语句 用 于 向 
DropDownListl 控件 中 添加 4 项 : 


DropDownList1. Items. Add(" 打 球 "); 
DropDownList1. Items. Add(" 跑 步 "); 
DropDownList1. Items. Add(" 看 书 "); 
DropDownList1. Items. Add(" 上网"); 


图 6.17 “DropDownList 任务 ”菜单 
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上 网 层 性 (P): 
国 & | 5 


6.18 “Listltem 集合 编辑 器 ”对 话 框 


【 例 6.6】 在 ch6 网 站 中 设计 一 个 WebForm6 网 页 ,其 功能 是 说 明 DropDownList 控件 
的 使 用 方法 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch6 网 站 ,选择 "网 站 | 添加 新 项 ”命令 ,出现 “添加 新 
项 -ch6” 对 话 框 ,在 中 间 列 表 中 选择 Web 窗 体 ”, 将 文件 名 称 改 
为 WebForm6. aspx, 其 他 保持 默认 项 , 单 击 * 添 加 ”按钮 。 

@ 本 网 页 的 设计 界面 如 图 6.19 所 示 , 其 中 有 一 个 
DropDownList 控件 sel( 其 AutoPostBack 属性 设 为 True) 和 一 


图 6.19 WebForm6 网 页 ”个 标签 Labell (Text 属性 设 为 空 )。 在 该 网 页 上 设计 如 下 事件 
设计 界面 过 程 : 


[Label1] 


[TD | 


设计 | 加 拆 分 |。 源 | 四 < 


protected void Page_Load( object sender, EventArgs e) 
{ if (!Page. IsPostBack) 
{ ”sel. Items.Add(" 汉 族 "); 
sel. Items. Add( "满族 "); 
sel. Items. Add(" 回 族 "); 
sel. Items. Add(" 土 家 族 "); 
sel. Items. Add(" 其 他 "); 
sel. AutoPostBack = true; 
} 
} 
protected void sel_SelectedIndexChanged(object sender, EventArgs e) 
{ 
Labell. Text = "您 的 选择 是 "+ sel. SelectedItenm. Text; 
} 


@ 单 击 工具 栏 中 的 P Internet Explorer 按钮 运行 本 网 页 ,在 DropDownList 控件 sel 中 选择 
“回族 ” ,其 结果 如 图 6. 20 所 示 。 在 用 户 选 择 一 个 不 同 的 选项 时 ,将 信息 发 往 服 务 器 ,从 而 执行 
sel_SelectedIndexChanged 事件 过 程 。 如 果 AutoPostBack 属性 设置 为 False, 则 不 会 执行 sel_ 
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SelectedIndexChanged 事件 过 程 ( 它 是 服务 器 事件 过 程 ) 。 
6.3.2 ListBox 控件 


ListBox 控件 又 称 下 拉 列 表 框 控件 ,在 工具 箱 中 的 图 标 为 
ListBox ,对 应 命名 空间 System. Web. UI. WebControls 中 
的 ListBox 类 。ListBox 控件 允许 用 户 从 预定 义 列表 中 选择 一 
项 或 多 项 。 它 与 DropDownList 控件 的 不 同 之 处 在 于 它 可 一 次 
显示 多 项 ,也 可 允许 用 户 选 择 多 项 。ListBox 控件 的 常用 属性 。 图 6.20 WebForm6 网 页 


和 事件 如 表 6. 17 所 示 。 运行 界面 
表 6.17 ListBox 控件 的 常用 属性 和 事件 
类 型 名 称 说 明 
AutoPostBack 该 值 指 示 当 用 户 更 改 列表 中 的 选 定 内 容 时 是 否 自动 产生 向 服务 器 的 回 发 
DataMember 获取 或 设置 数据 绑 定 控件 绑 定 到 的 数据 列表 的 名 称 
DataSource 获取 或 设置 填充 ListBox 控件 的 数据 源 
DataTextField 获取 或 设置 为 ListBox 控件 提供 文本 内 容 的 数据 源 字段 
局 性 DataValueField 获取 或 设置 为 各 列表 项 提供 值 的 数据 源 字段 
| ltems 获取 ListBox 控件 项 的 集合 
Rows 获取 或 设置 ListBox 控件 中 显示 的 行 数 
Selectedltem 获取 ListBox 控件 中 索引 最 小 的 选 定 项 
获取 或 设置 ListBox 控件 的 选择 模式 ,可 选 Single( 只 能 选 一 项 ) 或 Multiple 
SelectedMode 
(可 以 选 多 项 ) 
事件 SelectedIndexChanged | 当 列 表 控件 的 选 定 项 在 信息 发 往 服 务 器 之 间 变 化 时 发 生 
TextChanged 当 Text 和 SelectedValue 属性 更 改 时 发 生 


ListBox 控件 的 Items 是 一 个 集合 属性 ,其 中 每 个 元 素 ( 项 ) 是 一 个 ListItem 对 象 。Items 
属性 用 来 设置 子 选 项 ,每 个 子 选 项 都 具有 索引 值 ,索引 值 开始 为 0。 实际 上 ,ListBox 控件 的 
Items 属性 也 是 一 个 ListItemCollection 类 对 象 , ListItemCollection 类 的 常用 属性 和 方法 如 
表 6.16 所 示 。 

向 ListBox 控件 中 添加 项 的 过 程 与 DropDownList 控件 的 过 程 相 似 。 在 设计 时 设置 
Items 属性 的 方法 是 单 击 ListBox 控件 右上 角 的 之 按 钮 ,出现 “ListBox 任务 ”菜单 ,选择 “编辑 
项 ”命令 ,打开 “ListItem 集合 编辑 器 对话 框 , 通 过 “添加 "按钮 增加 Items 属性 中 的 各 个 项 ,并 
输入 各 项 的 Text 和 Value 属性 值 。 若 对 于 ListBoxl 控件 添加 类 似 图 6. 18 的 4 个 项 ,对 应 的 
HTML 代码 如 下 : 

<asp:ListBox ID = "ListBoxl"”runat = "server"> 

<asp:ListItem > 打球 </asp:ListItem > 
<asp:ListItem > 跑步 </asp:ListItem > 
<asp:ListItem > 看 书 </asp:ListItem > 
<asp:ListItem> 上 网 </asp:ListItem > 

</asp:ListBox> 

用 户 也 可 以 在 运行 程序 时 动态 地 向 ListBox 控件 中 添加 项 。 例 如 ,以 下 语句 向 ListBoxtl 
控件 中 添加 4 个 项 ， 


ListBoxl. Items. Add(" 打 球 "); 
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ListBoxl. Items. Add( "跑步"); 
ListBoxl. Items. Add( "看书"); 
ListBoxl. Items. Add(" 上 网 "); 


与 DropDownList 控件 相同 ,车 要 执行 SelectedIndexChanged 等 事件 处 理 过 程 ,需要 将 该 


控件 的 AutoPostBack 属性 设置 为 True( 默 认 值 为 False)。 另 外 , 若 允 许多 行 选择 ,需要 将 
SelectionMode 设置 为 Multiple。 


【 例 6.7】 


方法 。 


解 : 其 步骤 如 下 。 

@ 打开 ch6 网 站 ,选择 “网 站 | 添加 新 项 "命令, 出现 “添加 新 项 -ch6” 对 话 框 ,在 中 间 列 表 中 
选择 "Web 窗 体 ”, 将 文件 名 称 改 为 WebForm7. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 。 

@ 本 网 页 的 设计 界面 如 图 6. 21 所 示 , 其 中 有 一 个 ListBox 控件 ListBoxl 和 一 个 标签 


Labell(Text 


在 ch6 网 站 中 设计 一 个 WebForm7 网 页 ,其 功能 是 说 明 ListBox 控件 的 使 用 


属性 设 为 空 ) 。 在 该 网 页 上 设计 如 下 事件 过 程 : 


Protected void Page_Load( object sender, EventArgs e) 
# if (!Page. IsPostBack) 


{ 


} 


ListBoxl. 
ListBoxl . 
ListBoxl . 
ListBoxl. 
.Items. hdd( "吉林 大学 ") 
ListBoxl . 


ListBoxl 


Items. Add(" 北 京 大 学 "); 
Items. Add( "清华 大 学 "); 
Items. Add( "南京 大 学 "); 
Items. Add(" 武 汉 大 学 "); 


Items. Add( "湖南 大 学 "); 


ListBox1. AutoPostBack = True; 
ListBoxl.Rows = 5; 
ListBoxl. SelectionMode = System. Web. UI. WebControls. ListSelectionMode. Multiple; 


} 


protected void ListBoxl_SelectedIndexChanged(object sender, EventArgs e) 
{ stringmystr 


foreach (ListItem it in ListBoxl. Items) 


Labell. Text = "你 选择 的 是 : ”+ mystr; 


} 


Pr 
过 


if (it.Selected == True) 
mystr = mystr + 让 .Text + " gnbsp; "; 


@ 单 击 工 具 栏 中 的 > iInternet Explorer 按钮 运行 本 网 页 , 按 下 Ctrl 键 不 放 , 从 ListBoxl 控件 
中 选择 “清华 大 学 ”和 “武汉 大 学 ”两 项 ,其 结果 如 图 6. 22 所 示 。 


图 6. 21 


拆 分 | 源 | 4 -| 


WebForm?7 网 页 设计 界面 


图 6.22 WebForm7 网 页 运行 界面 
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6.3.3 ”RadioButtonList 控件 


RadioButtonList 控件 又 称 单 选 按钮 列表 控件 ,在 工具 箱 中 的 图 标 为 哇 ”RadioButtonlist ,对 
应 命名 空间 System. Web. UI. WebControls 中 的 RadioButtonList 类 。RadioButtonList 控件 
用 于 构建 单 选 按钮 列表 ,人 允许 用 户 互 斥 地 从 列表 中 选择 一 个 。RadioButtonList 控件 的 常用 属 
性 和 事件 如 表 6. 18 所 示 。 
表 6.18 RadioButtonList 控件 的 常用 属性 和 事件 
类 型 名 称 说 明 
获取 或 设置 一 个 值 ,该 值 指示 当 用 户 更 改 列表 中 的 选 定 内 容 时 是 否 自动 产 


AutoPostBack 生 向 服务 器 的 回 发 
ltems 表示 控件 对 象 中 所 有 项 的 集合 
SelectedIndex 获取 或 设置 列表 中 选 定 项 的 最 低 序号 索引 
Selectedltem 获取 列表 控件 中 索引 最 小 的 选 定 项 
SelectedValue 获取 列表 控件 中 选 定 项 的 值 , 或 选择 列表 控件 中 包含 指定 值 的 项 
Text 获取 或 设置 RadioButtonList 控件 的 SelectedValue 属性 
RepeatColumns 获取 或 设置 要 在 RadioButtonList 控件 中 显示 的 列 数 
属性 获取 或 设置 组 中 单 选 按钮 的 显示 方向 , 值 为 Horizontal 表示 列表 项 以 行 的 


形式 水 平 显示 ,从 左 到 右 、. 自 上 而 下 地 加 载 ,直到 呈现 出 所 有 的 项 ; 值 为 
Vertical( 默 认 值 ?表示 列表 项 以 列 的 形式 垂直 显示 , 自 上 而 下 .从 左 到 右 地 加 
载 ,直到 呈现 出 所 有 的 项 

获取 或 设置 一 个 值 , 该 值 指定 是 否 将 使 用 table 元 素 (默认 值 ) .ul 元 素 、ol 元 
素 或 span 元 素来 呈现 列表 

获取 或 设置 组 内 单 选 按钮 的 文本 对 齐 方 式 , 取 值 为 Left 表示 与 单 选 按钮 控 
TextAlign 件 关联 的 文本 显示 在 该 控件 的 左 侧 ; 取 值 为 Right( 默 认 值 ) 表 示 与 单 选 按钮 
控件 关联 的 文本 显示 在 该 控件 的 右 侧 

CheckedIndexChanged | 当 列 表 控件 的 选 定 项 在 信息 发 往 服务 器 之 间 变 化 时 发 生 

TextChanged 当 Text 和 SelectedValue 属性 更 改 时 发 生 


RepeatDirection 


RepeatLayout 


事件 


RadioButtonList 控件 中 的 Items 属性 用 来 设置 子 选 项 ,每 个 子 选项 都 具有 索引 值 , 索 引 
值 开始 为 0; Items 是 ListItemCollection 类 的 对 象 ,而 ListItemCollection 类 的 常用 属性 和 方法 如 
表 6. 16 所 示 。 在 RadioButtonList 控件 中 使 用 一 组 Selected 属性 来 判断 子 选项 是 否 被 选中 。 

和 ListBox 一 样 ,用 户 可 以 通过 “ListItem 集合 编辑 器 ”对话 框 添加 RadioButtonList 控件 
的 各 个 选项 。 同 样 ,RadioButtonList 控件 的 主要 事件 是 SelectedIndexChanged, 当 用 户 单 击 
其 中 的 一 个 选项 时 引发 执行 对 应 的 事件 处 理 过 程 ,但 需要 设置 其 AutoPostBack 属性 为 True。 

在 默认 情况 下 ,RadioButtonList 控件 只 显示 一 列 按钮 。 开 发 人 员 可 以 将 RadioButtonList 控 
件 的 RepeatColumns 属性 设置 为 所 需 的 列 数 ,在 这 些 列 中 还 可 以 使 用 RepeatDirection 枚 举 将 
RepeatDirection 属性 设置 为 Vertical( 默 认 值 ) 或 Horizontal。 

【 例 6.8】 在 ch6 网 站 中 设计 一 个 WebForm8 网 页 ,其 功能 是 说 明 RadioButtonList 控件 
的 使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch6 网 站 ,选择 “网 站 | 添加 新 项 "命令 ,出 现 “ 添 加 新 项 -ch6” 对 话 框 , 在 中 间 列 表 中 
选择 "Web 窗 体 ”, 将 文件 名 称 改 为 WebForm8. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 。 
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@ 本 网 页 的 设计 界面 如 图 6. 23 所 示 。 插 入 一 个 5X2 的 表格 ,将 第 1 行 的 两 列 合 并 ( 选 
中 要 合并 的 两 列 , 选 择 “ 表 | 修改 | 合并 单元 格 " 命 令 即 可 ) ,输入 “个 人 信息 ”; 在 第 2 行 第 1 列 输 
入 “性 别 ”, 在 第 2 行 第 2 列 拖 放 一 个 RadioButtonListl 控件 (RepeatColumns 属性 设置 为 2) ,通过 
“ListItem 集合 编辑 器 对话 框 添加 两 个 选项 ,该 控件 对 应 的 HTML 代码 如 下 : 


<asp:RadioButtonList ID = "RadioButtonList1" runat = "server" 
CssClass = "auto — style6" RepeatColumns = "2"> 
<asp:ListItem> 男 </asp:ListItem> 
<asp:ListItem> 女 </asp:ListItem> 
</asp:RadioButtonList > 


在 第 3 行 第 1 列 输入 “民族 ”, 在 第 3 行 第 2 列 拖 放 一 个 RadioButtonList2 控件 
(RepeatColumns 属性 设置 为 3) ,通过 “ListItem 集合 编辑 器 ?对话 框 添加 5 个 选项 ,该 控件 对 
应 的 HTML 代码 如 下 : 


<asp:RadioButtonList ID = "RadioButtonList2" runat = "server" 
CssClass = "auto — style6" RepeatColumns = "3" Width = "199px"> 
<asp:ListItem > 汉族 </asp:ListItem> 
<asp:ListItem> 回 族 </asp:ListItem > 
<asp:ListItem> 满 族 </asp:ListItem > 
<asp:ListItem> 土 家 族 </asp:ListItem> 
<asp:ListItem> 其 他 </asp:ListItem > 
</asp:RadioButtonList > 


将 第 4 行 的 两 列 合 并 , 拖 放 一 个 Buttonl 控件 (其 Text 设置 为 “确定 ”); 将 第 5 行 的 两 列 
合并 , 拖 放 一 个 Labell 控件 (其 Text 设置 为 空 )。 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Buttonl_Click(object sender, EventArgs e) 
{ stringmystr="", mystrl=""; 
foreach (ListItem it in RadioButtonList1. Items) 
if (让 .Selected == True) 
mystr = 让 .Text + " "; 
foreach (ListItem it in RadioButtonList2. Items) 
if (让 .Selected == True) 
mystrl = it.Text + " "; 
Labell. Text = "性 别 为 :"+ mystr + "<br>”+ "民族 为 :"+ mystrl; 


} 


@ 单 击 工 具 栏 中 的 Pp Internet Explorer 按钮 运行 本 网 页 ,从 RadioButtonListl 控件 中 选择 
“ 女 ”, 从 RadioButtonList2 控件 中 选择 “回族 ”, 单 击 “ 确 定 ” 命 令 按 钮 ,其 结果 如 图 6. 24 所 示 。 


| 个 人 信息 
| 
性 别 | 个 男 个 女 
人 汉族 满族 C 其 他 
民族 | C 回族 ~ 土家 族 
| 〇 汉族 ” 口 满 族 口 其 他 
[确定 | | 加 回族 〇 土家 族 
[Labell] 
4 » 到 
设计 | 日 折 分 |。 源 | [4] <asp:RadioButtonlistautc 


图 6.23 WebForm8 网 页 设计 界面 图 6.24 WebForm8 网 页 运行 界面 
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说 明 : 本 例 不 同 于 例 6.6 和 例 6.7, 没 有 使 用 RadioButtonListl 控件 的 CheckedIndexChanged 
事件 ,所 以 RadioButtonList 控件 的 AutoPostBack 不 必 设 置 为 True。 


6.3.4 CheckBoxList 控件 
CheckBoxList 控件 又 称 为 复 选 框 列 表 控 件 ,在 工具 箱 中 的 图 标 为 距 checkeoxuis ,对 应 命名 
空间 System. Web. UI. WebControls 中 的 CheckBoxList 类 。CheckBoxList 控件 与 CheckBox 
控件 类 似 , 不 同 之 处 是 前 者 只 有 一 个 复 选 框 , 后 者 可 以 包含 多 个 复 选 框 。 它 的 常用 属性 和 事件 
如 表 6. 19 所 示 。 
表 6.19 CheckBoxList 控件 的 常用 属性 和 事件 


类 型 名 称 说 明 
获取 或 设置 一 个 值 ,该 值 指示 当 用 户 更 改 列表 中 的 选 定 内 容 时 是 否 自 动产 
AutoPostBack 
生 向 服务 器 的 回 发 
Items 表示 控件 对 象 中 所 有 项 的 集合 
SelectedIndex 获取 或 设置 列表 中 选 定 项 的 最 低 序号 索引 
Selectedltem 获取 列表 控件 中 索引 最 小 的 选 定 项 
SelectedValue 获取 列表 控件 中 选 定 项 的 值 ,或 选择 列表 控件 中 包含 指定 值 的 项 
属性 | Text 获取 或 设置 CheckBoxList 控件 的 SelectedValue 属性 
RepeatColumns 获取 或 设置 要 在 CheckBoxList 控件 中 显示 的 列 数 


获取 或 设置 一 个 值 ,该 值 指示 控件 是 垂直 显示 还 是 水 平 显 示 , 取 值 与 
RadioButtonList 控件 的 该 属性 相同 
获取 或 设置 一 个 值 ,该 值 指定 是 否 将 使 用 table 元 素 ( 默 认 值 ) .ul 元 素 .ol 元 


RepeatDirection 


RepeatLayout 


素 或 span 元 素来 呈现 列表 
TextAlign 与 RadioButtonList 控件 的 该 属性 相同 
事件 CheckedIndexChanged | 当 列 表 控件 的 选 定 项 在 信息 发 往 服务 器 之 间 变 化 时 发 生 
TextChanged 当 Text 和 SelectedValue 属性 更 改 时 发 生 


CheckBoxList 控件 中 的 Ttems 属性 用 来 设置 子 选项 ,每 个 子 选项 都 是 一 个 ListItem 对 象 ,都 
具有 索引 值 ,索引 值 开始 为 0。Items 是 ListItemCollection 类 的 对 象 , 而 ListItemCollection 类 的 
常用 属性 和 方法 如 表 6. 16 所 示 。 在 CheckBoxList 控件 中 使 用 一 组 Selected 属性 来 判断 子 选 
项 是 否 被 选中 。 若 要 确定 CheckBoxList 控件 中 的 选 定 项 ,可 以 循环 访问 Items 集合 并 测试 该 
集合 中 每 一 项 的 Selected 属性 。 

和 ListBox 一 样 ,用 户 可 以 通过 “ListItem 集合 编辑 器 "对话 框 添加 CheckBoxList 控件 的 
各 个 选项 。 同 样 ,CheckBoxList 控件 的 主要 事件 是 SelectedIndexChanged, 当 用 户 单 击 其 中 的 
一 个 选项 时 引发 执行 对 应 的 事件 处 理 过 程 ,但 需要 设置 其 AutoPostBack 属性 为 True。 

在 默认 情况 下 ,CheckBoxList 控件 只 显示 一 列 按钮 。 开 发 人 员 可 以 将 CheckBoxList 控 
件 的 RepeatColumns 属性 设置 为 所 需 的 列 数 . 在 这 些 列 中 还 可 以 使 用 RepeatDirection 枚 举 将 
RepeatDirection 属性 设置 为 Vertical( 默 认 值 ) 或 Horizontal。 

【 例 6.9】 在 ch6 网 站 中 设计 一 个 WebForm9 网 页 ,其 功能 是 说 明 CheckBoxList 控件 的 
使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch6 网 站 ,选择 “网 站 | 添加 新 项 "命令, 出现“ 添加 新 项 -ch6” 对 话 框 ,在 中 间 列 表 中 
选择 “Web 窗 体 ”. 将 文件 名 称 改 为 WebForm9. aspx. 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 。 
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@ 本 网 页 的 设计 界面 如 图 6. 25 所 示 。 插 入 一 个 5X2 的 表格 ,将 第 1 行 的 两 列 合并 ( 选 
中 要 合并 的 两 列 ,选择 “ 表 | 修 改 | 合并 单元 格 " 命 令 即 可 ), 输 入 “个 人 信息 ” 在 第 2 行 第 1 列 
输入 “爱好 ”, 在 第 2 行 第 2 列 拖 放 一 个 CheckBoxListl 控件 (RepeatColumns 属性 设置 为 4)， 
通过 “ListItem 集合 编辑 器 ?对 话 框 添加 4 个 选项 ,该 控件 对 应 的 HTML 代码 如 下 : 


<asp:CheckBoxList ID = "CheckBoxList1l" runat = "server" CssClass = "auto— style7" 
RepeatColumns = "4" Width= "146px"> 
<asp:ListItem> 打 球 </asp:ListItem> 
<asp:ListItem> 跑 步 </asp:ListItem > 
<asp:ListItem> 看 书 </asp:ListItem > 
<asp:ListItem> 上 网 </asp:ListItem > 
</asp:CheckBoxList > 


在 第 3 行 第 1 列 输入 “特长 ”, 在 第 3 行 第 2 列 拖 放 一 个 CheckBoxList2 控件 (保持 
RepeatColumns 属性 默认 值 0) ,通过 “ListItem 集合 编辑 器 ”对话 框 添加 3 个 选项 ,该 控件 对 应 
的 HTML 代码 如 下 : 


<asp:CheckBoxList ID = "CheckBoxList2" runat = "server" CssClass = "auto— style7"> 
<asp:ListItem> 夯 画 </asp:ListItem> 
<asp:ListItem> 表 演 </asp:ListItem > 
<asp:ListItem > 计算 机 编程 </asp:ListItem> 

</asp:CheckBoxList > 


将 第 4 行 的 两 列 合 并 , 拖 放 一 个 Buttonl 控件 (其 Text 设置 为 “确定 ”); 将 第 5 行 的 两 列 
合并 , 拖 放 一 个 Labell 控件 (其 Text 设置 为 空 )。 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Button1_Click(object sender, EventArgs e) 
{ stringmystr="",mystrl="" 
foreach (ListItem it in CheckBoxList1. Items) 
if (让 .Selected == True) 
mystr += 让 .Text + " "; 
foreach (ListItem it in CheckBoxList2. Items) 
if (it.Selected == True) 
mystrl += it.Text + " "; 
Labell. Text = "爱好 为 :”+ mystr + "<br>”+ "特长 为 :”+ mystrl; 
} 


@ 单 击 工具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 ,从 CheckBoxListl 控件 中 色 选 第 1、4 
两 项 ,从 CheckBoxList2 控件 中 色 选 第 1、3 两 项 , 单 击 “ 确 定 ” 命 令 按钮 ,其 结果 如 图 6. 26 所 示 。 


上 四 去 

| 站 【< Oe Co 
| | | | 
| PE 

全 好 | 打 驳 看 上 | 
| 球 步 书 网 

厂 画 画 

特长 厂 表 演 | 

| 厂 计 算 机 编程 
确定 
[Label1] 

I 爱好 为 :打球 上 网 
5 特长 为 : 画 画 计算 机 编程 
5 设计 | 拆 分 1°。 淹 | [4] <dv> 中 | 

图 6.25 WebForm9 网 页 设计 界面 图 6.26 WebForm9 网 页 运行 界面 


183 
第 6 章 Web 标准 服务 器 控 


说 明 : 本 例 不 同 于 例 6.6 和 例 6.7, 没 有 使 用 CheckBoxListl 控件 的 CheckedIndexChanged 
事件 ,所 以 CheckBoxList 控件 的 AutoPostBack 不 必 设 置 为 True。 


6.3.5 ”BulletedLisit 控件 


BulletedList 控件 在 工具 箱 中 的 图 标 为 汪 Bulleteduist ,对 应 命名 空间 System. Web. UL 
WebControls 中 的 BulletedList 类 。BulletedList 控件 用 于 生成 一 个 采用 项 目 符号 格式 的 项 列 
表 , 其 常用 属性 和 事件 如 表 6. 20 至 表 6. 22 所 示 。 


表 6.20 BulletedList 控件 的 常用 属性 和 事件 


类 型 名 称 说 明 
BulletStyle 获取 或 设置 BulletedList 控件 的 项 目 符号 样式 ,其 取 值 如 表 6. 21 所 示 
BulletImageUrl 获取 或 设置 为 BulletedList 控件 中 的 每 个 项 目 符号 显示 的 图 像 的 路 径 
DisplayMode 获取 或 设置 BulletedList 控件 中 的 列表 内 容 的 显示 模式 ,其 取 值 如 表 6. 22 所 示 
FirstBulletNumber ”| 获取 或 设置 排序 BulletedList 控件 中 开始 列表 项 编号 的 值 

属性 | ltems 表示 控件 对 象 中 所 有 项 的 集合 
SelectedIndex 获取 或 设置 BulletedList 控件 中 当前 选 定 项 的 从 零 开 始 的 索引 
Selectedltem 获取 BulletedList 控件 中 的 当前 选 定 项 
SelectedValue 获取 或 设置 BulletedList 控件 中 选 定 Listltem 对 象 的 Value 属性 
Text 获取 或 设置 BulletedList 控件 的 文本 
Click 当 单 击 BulletedList 控件 中 的 链接 按钮 时 发 生 

事件 | TextChanged 当 Text 和 SelectedValue 属性 更 改 时 发 生 
SelectedIndexChanged | 当 列 表 控件 的 选 定 项 在 信息 发 往 服务 器 之 间 变 化 时 发 生 


表 6.21 BulletStyle 属性 取 值 及 其 说 明 


项 目 符号 样式 说 明 项 目 符号 样式 说 明 
NotSet 未 设置 UpperRoman 大 写 罗 马 数字 
Numbered 数字 Disc 实心 贺 
LowerAlpha 小 写字 母 Circle 圆圈 
UpperAlpha 大 写字 母 Square 实心 正方 形 
LowerRoman 小 写 罗 马 数字 Customlmage 自 定义 图 像 


表 6.22 DisplayMode 属性 取 值 及 其 说 明 


值 说 明 
Text 静态 文本 。 由 控件 所 显示 的 文本 不 是 交互 式 的 
HyperLink 超 链接 。 用 户 可 以 单 击 链接 以 导航 到 另 一 个 网 页 ,但 必须 提供 目标 URL 作为 各 个 
项 的 Value 属性 
LinkButton 链接 按钮 。 用 户 可 以 单 击 单个 项 ,然后 控件 将 执行 一 次 回 发 


使 用 FirstBulletNumber 属性 来 指定 排序 BulletedList 控件 中 开始 列表 项 编号 的 值 。 如 
果 将 BulletStyle 属性 设置 为 Disc、Square、Circle 或 CustomImage 类 型 , 则 忽略 分 配给 
FirstBulletNumber 属性 的 值 ; 如 果 将 BulletStyle 属性 设置 为 CustomImage 的 值 ,以 指定 项 
目 符号 的 自 定义 图 像 . 还 必须 设置 BulletImageUrl 属性 以 指定 图 像 文件 的 位 置 。 

若 要 指定 BulletedList 中 列表 项 的 显示 行为 ,需要 设置 DisplayMode 属性 。 若 为 超 链 接 
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(HyperLink) 行 为 , 则 单 击 超 链 接 时 将 定位 到 相应 的 URL., 需 要 使 用 Value 属性 指定 超 链接 
定位 到 的 URL, 并 使 用 Target 属性 指定 框架 或 窗口 。 若 为 链接 按钮 (LinkButton) 行 为 ， 
BulletedList 控件 将 列表 项 显示 为 链接 , 单 击 这 些 链 接 将 回 发 到 服务 器 ,如 果 要 以 编程 方式 控 
制 单 击 链接 按钮 时 执行 的 操作 ,需要 设计 Click 事件 处 理 过 程 。 

注意 : SelectedIndex 和 SelectedItem 属性 是 从 ListControl 类 继承 而 来 的 ,不 适用 于 
BulletedList 控件 ,用 户 可 以 使 用 BulletedListEventArgs 类 的 事件 数据 来 确定 单 击 的 BulletedList 
中 的 链接 按钮 的 索引 。 

在 设计 时 设置 Items 属性 的 方法 与 ListBox 相似 ,通过 “ListItem 集合 编辑 器 ”对 话 框 来 
添加 Items 属性 中 的 各 个 项 ,并 输入 各 项 的 Text 和 Value 属性 值 。 

【 例 6.10】 在 ch6 网 站 中 设计 一 个 WebForml0 网 页 ,其 功能 是 说 明 BulletedList 控件 的 
使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch6 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch6” 对 话 框 ,在 中 间 列 表 中 
选择 “Web 窗 体 ”, 将 文件 名 称 改 为 WebForm10. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 。 

@ 本 网 页 的 设计 界面 如 图 6. 27 所 示 。 插 入 一 个 3X3 的 表格 ,将 第 1 行 的 两 列 合 并 , 输 
人 “BulletedList 控件 ”; 在 第 2 行 第 1 列 拖 放 一 个 BulletedListl 控件 (DisplayMode 属性 取 默 
认 值 text) ,通过 “ListItem 集合 编辑 器 对话 框 添加 4 个 选项 并 设置 相应 的 属性 ,该 控件 对 应 
的 HTML 代码 如 下 : 


<asp:BulletedList ID = "BulletedList1" runat = "server" BulletStyle = "Circle" 
CssClass = "auto — style3"> 
<asp:ListItem> 蔷 果 </asp:ListItem > 
<asp:ListItem > 葡萄 </asp:ListItem > 
<asp:ListItem> 李 子 </asp:ListItem > 
<asp:ListItem> 香 攀 </asp:ListItem> 
</asp:BulletedList > 


在 第 2 行 第 2 列 拖 放 一 个 BulletedList2 控件 (DisplayMode 属性 取 默 认 值 HyperLink)， 
通过 "ListItem 集合 编辑 器 "对话 框 添加 4 个 选项 并 设置 相应 的 属性 ,该 控件 对 应 的 HTML 代 
码 如 下 : 


<asp:BulletedList ID = "BulletedList2" runat = "server" BulletStyle = "UpperAlpha" 
CssClass = "auto - style3" DisplayMode = "HyperLink"> 
<asp:ListItem Value = "WebForm1l.aspx"> WebForml </asp:ListItem> 
<asp:ListItem Value = "WebForm2.aspx"> WebForm2 </asp:ListItem> 
<asp:ListItem Value = "WebForm3.aspx"> WebForm3 </asp:ListItem> 
<asp:ListItem Value = "WebForm4.aspx"> WebForm4 </asp:ListItem> 
</asp:BulletedList > 


在 第 2 行 第 3 列 拖 放 一 个 BulletedList3 控件 (DisplayMode 属性 取 默 认 值 LinkButton ) , 
通过 “ListItem 集合 编辑 器 ”对话 框 添加 5 个 选项 并 设置 相应 的 属性 ,该 控件 对 应 的 HTML 代 
码 如 下 : 


<asp:BulletedList ID = "BulletedList3" runat = "server" BulletStyle = "Numbered" 
CssClass = "auto - style3" DisplayMode = "LinkButton" FirstBulletNumber = "10" 
OnClick = "BulletedList3_Click"> 
<asp:ListItem > 中国 </asp:ListItem> 
<asp:ListItem > 美国 </asp:ListItem> 
<asp:ListItem > 俄罗斯 </asp:ListItem> 
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<asp:ListItem > 英国 </asp:ListItem> 
<asp:ListItem > 法 国 </asp:ListItem > 
</asp:BulletedList > 


@ 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void BulletedList3_Click(object sender, BulletedListEventArgs e) 


E 
Labell. Text = "您 的 选择 : "+ BulletedList3. Items[e. Index]. Text; 


} 

@ 单 击 工 具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,在 该 网 页 中 ,BulletedListl 控件 仅仅 
用 于 显示 信息 ,不 能 交互 ; 单 击 BulletedList2 控件 中 的 某 一 个 选项 时 转向 相应 的 网 页 ; 单 击 
BulletedList3 控件 中 的 某 一 个 选项 时 执行 BulletedList3_Click 事件 过 程 ,图 6. 28 所 示 的 是 单 
击 BulletedList3 控件 中 的 第 一 个 选项 的 显示 结果 。 
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BulletedList 
人 BulletedList 控 件 
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WebForm3 
WebForm4 


pomp 


[Label1] 


您 的 选择 : 中 国 
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图 6.27 WebForm10 网 页 设计 界面 图 6.28 WebForml0 网 页 运行 界面 


6.4 常用 的 其 他 标准 控件 


本 节 介 绍 FileUpload、View/MultiView 和 Wizard 控件 。 
6.4.1 FileUpload 控件 


FileUpload 控件 在 工具 箱 中 的 图 标 为 和 锦 FileUpload ,对 应 命名 空间 System. Web. UL. 
WebControls 中 的 FileUpload 类 。FileUpload 控件 显示 一 个 文本 框 控 件 和 一 个 “浏览 ”按钮 ， 
使 用 户 可 以 选择 要 上 传 到 服务 器 的 文件 ,其 常用 属性 和 方法 如 表 6. 23 所 示 。 


表 6.23 FileUpload 控件 的 常用 属性 和 方法 
类 型 | 名 称 说 明 


FileBytes 从 使 用 FileUpload 控件 指定 的 文件 返回 一 个 字 节 数组 


FileContent | 获取 Stream 对 象 , 它 指向 要 使 用 FileUpload 控件 上 传 的 文件 


属性 | FileName 获取 客户 端 上 使 用 FileUpload 控件 上 传 的 文件 的 名 称 


HasFile 获取 一 个 值 .该 值 指示 FileUpload 控件 是 否 包含 文件 


PostedFile 获取 使 用 FileUpload 控件 上 传 的 文件 的 HttpPostedFile 对 象 


方法 | SaveAs 使 用 FileUpload 控件 将 上 传 的 文件 的 内 容 保存 到 Web 标准 服务 器 上 的 指定 路 径 


185 


186 
SP.NET 4. 5 动态 网 站 设计 教程 一 一 基于 C# 5.0 十 SQL Server 2012 
FileUpload 控件 的 PostedFile 属性 是 HttpPostedFile 类 对 象 ,而 HttpPostedFile 类 提供 
对 客户 端 已 上 传 的 单独 文件 的 访问 ,其 常用 属性 和 方法 如 表 6. 24 所 示 。 
表 6.24 HttpPostedFile 类 的 常用 属性 和 方法 
类 型 名 称 说 明 


ContentLength | 获取 上 传 文件 的 大 小 (以 字 节 为 单位 ) 
ContentType 获取 客户 端 发 送 的 文件 的 MIME 内 容 类 型 


属性 「 REName 获取 客户 端 上 的 文件 的 完全 限定 名 称 
InputStream | 获取 一 个 Steam 对 象 \ 该 对 象 指向 一 个 上 传 文 作 , 以 准备 读 取 该 文件 的 内 容 
| Save 保存 上 传 文件 的 内 容 


在 用 户 选择 要 上 传 的 文件 后 ,FileUpload 控件 不 会 自动 将 该 文件 保存 到 服务 器 ,必须 显 式 
地 提供 一 个 控件 或 机 制 ,使 用 户 能 提交 指定 的 文件 。 例 如 可 以 提供 一 个 命令 按钮 ,用 户 单 击 它 
即 可 上 传 文件 。 另 外 ,为 保存 指定 文件 应 调用 SaveAs 方法 ,该 方法 将 文件 内 容 保存 到 服务 器 
上 的 指定 路 径 。 

【 例 6. 11】 在 ch6 网 站 中 设计 一 个 WebFormll 网 页 ,其 功能 是 说 明 FileUpload 控件 的 
使 用 方法 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch6 网 站 ,选择 “网 站 | 添加 新 项 ” 


[FEI  - 
命令 ,出 现 “ 添 加 新 项 -ch6” 对 话 框 ,在 中 间 列 表 ~ 
击 览 .. . 
中 选择 “Web 窗 体 ”, 将 文件 名 称 改 为 
WebFormll. aspx, 其 他 保持 默认 项 , 单 击 “ 添 0 
加 ”按钮 。 [Label1] 
@ 在 ch6 网 站 中 建立 一 个 存放 上 传 文件 革 | 
设计 | 日 拆 分 | ” 源 | <div>| <asp:Button#Buttonl> 
的 子 目 录 。 El au 昌 
@ 本 网 页 的 设计 界面 如 图 6. 29 所 示 , 其 图 6.29 WebFormll 网 页 设计 界面 


中 有 一 个 FileUpload 控件 FileUploadl (由 一 
个 文本 框 和 “浏览 ”按钮 组 成 ) 一 个 命令 按钮 Buttonl 和 一 个 标签 Labell。 在 该 网 页 上 设计 如 
下 事件 过 程 : 


protected void Button1_Click(object sender, EventArgs e) 
4 string filestr; 
if (FileUploadl. HasFile) 
{ filestr = Server.MapPath("")+"\\File\\" +FileUploadl.PostedFile. FileName; 
try 
{ FileUploadl. PostedFile. SaveAs(filestr); 
Labell.Text = "提示 : 文件 成 功 上 传 到 ”+ filestr; 


} 
catch (Exception ex) 
{ 
Labell.Text = "提示 : 文件 上 传 失败 ,”+ ex. Message; 
} 
else 


Labell.Text = "提示 : 没有 指定 任何 要 上 传 的 文件 "; 
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@ 单 击 工 具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 , 单 击 “ 浏 览 ” 按 钮 ,在 出 现 的 “选择 要 
加 载 的 文件 ”对 话 框 中 选择 一 个 要 上 传 的 文件 058328-01. pdf, 单 击 * 上 传 ”命令 按钮 ,其 结果 如 
6. 30 所 示 , 将 指定 的 文件 复制 到 *D:\ASP.NET\ch6\File” 目 录 中 。 


击 览 . - - 


上 上 传 


提示 : 文件 成 功 上 传 到 D: \ASP. NET\ch6\File\058328-01. pdf 


图 6.30 WebFormll 网 页 运行 界面 


6.4.2 View 控件 和 MultiView 控件 
View 控件 是 一 组 控件 的 容器 ,在 工具 箱 中 的 图 标 为 量 view ,对 应 命名 空间 System 
Web. UI. WebControls 中 的 View 类 。View 控件 必须 始终 包含 在 MultiView 控件 中 。 在 运行 
网 页 时 ,除非 激活 View 控件 ,否则 其 包含 的 内 容 不 会 呈现 。View 控件 的 常用 事件 如 表 6. 25 
所 示 。 
表 6.25 View 控件 的 常用 事件 


事件 说 明 
Activate 当前 View 控件 成 为 活动 视图 时 发 生 
Deactivate 当前 的 活动 View 控件 变 为 非 活动 时 发 生 


MultiView 控件 在 工具 箱 中 的 图 标 为 惫 Mukiview ,对 应 命名 空间 System. Web. UI. 
WebControls 中 的 MultiView 类 。 它 是 一 组 View 控件 的 容器 ,使 用 它 可 定义 一 组 View 控 
件 ,其 中 每 个 View 控件 都 包含 子 控件 。 然 后 ,应 用 程序 可 根据 用 户 标识 、 用 户 首选 项 以 及 在 
查询 字符 串 参 数 中 传递 的 信息 等 条 件 向 客户 端 呈 现 特定 的 View 控件 。MultiView 控件 的 常 
用 事件 如 表 6. 26 所 示 。 

表 6.26 ”MaultiView 控件 的 常用 属性 和 事件 
类 型 名 称 说 明 
属性 ”ActiveViewIndex 获取 或 设置 MultiView 控件 的 活动 View 控件 的 索引 
事件 ”ActiveViewChanged 当 MultiView 控件 的 活动 View 控件 在 两 次 服务 器 发 送 间 发 生 更 改 时 发 生 


在 MultiView 控件 中 一 次 只 能 将 一 个 View 控件 定义 为 活动 视图 。 如 果 将 某 个 View 控 
件 定义 为 活动 视图 , 它 所 包含 的 子 控件 则 会 呈现 到 客户 端 。 用 户 可 以 使 用 ActiveViewIndex 
属性 或 SetActiveView 方法 定义 活动 视图 。 如 果 ActiveViewIndex 属性 为 空 , 则 MultiView 
控件 不 向 客户 端 呈 现任 何 内容 。 

【 例 6.12】 在 ch6 网 站 中 设计 一 个 WebForml2 网 页 ,其 功能 是 说 明 View 控件 和 
MultiView 控件 的 使 用 方法 。 
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解 : 其 步骤 如 下 。 

@ 打开 ch6 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch6” 对 话 框 ,在 中 间 列 表 中 
选择 “Web 窗 体 ”, 将 文件 名 称 改 为 WebForm12. 
aspx， 其 他 保持 默认 项 , 单 击 “添加 ”按钮 。 


@ 本 网 页 的 设计 界面 如 图 6. 31 所 示 , 首 先 派 | ae 草 对 国 可 
加 一 个 MultiView 控件 MultiViewl, 再 向 其 中 添 Mviewl 


加 两 个 View 控件 Viewl 和 View2, 在 Viewl 控件 学 号 : 姓名 : 
中 添加 两 个 HTML 标记 和 两 个 文本 框 (TextBoxl jiapery 
和 TextBox2) ,在 View2 控件 中 添加 一 个 标签 
1 5 
Labell。 另 外 ,在 网 页 的 上 方 添加 两 个 命令 按钮 | [siat|e 折 人 |o 禁 | [| 
Button1(Text 为 “输入 ”) 和 Button2(Text 为 “ 输 
出 ”)。 在 该 网 页 上 设计 如 下 事件 过 程 : 
protected void Buttonl_Click(object sender, EventArgs e) 
{ VM/ 输 入 命令 按钮 的 单 击 事件 过 程 
MultiView1.RctiveViewIndex = 0; 
} 
protected void Button2_Click(object sender, EventArgs e) 
{ VW/ 输出 命令 按钮 的 单 击 事件 过 程 
MultiViewl. ActiveViewIndex = 1; 
Labell. Text = "学 号 :" + TextBoxl.Text + " 姓名 :" + TextBox2. Text; 
} 
@ 单 击 工具 栏 中 的 上 Inmternet Explorer 按钮 运行 本 网 页 , 单 击 “ 输 入 "命令 按钮 显示 Viewl 控 
件 ,输入 相应 数据 ,如 图 6. 32 所 示 。 再 单 击 * 输 出 命令 按钮 显示 View2 控件 ,其 结果 如 图 6. 33 
所 示 。 


图 6.31 WebForml2 网 页 设计 界面 


狠 ntpy/localhost5652 DP- ON ve 
@ localhost 


学 号 :106 姓名 : 王 华 


图 6.32 WebForml2 网 页 运行 界面 一 图 6.33 WebForml2 网 页 运行 界面 二 


6.4.3 Wizard 控件 


Wizard 控件 又 称 为 向 导 控件 , 在 工具 箱 中 的 图 标 为 右 Wizard ,对 应 命名 空间 System. 
Web. UI. WebControls 中 的 Wizard 类 。 通 过 该 控件 能 够 快速 实现 向 导 功 能 ,其 使 用 比 其 他 控 
件 复 杂 。Wizard 控件 的 常用 属性 和 事件 如 表 6. 27 所 示 。 

一 个 Wizard 控件 由 多 个 步骤 构成 ,用 WizardSteps 属性 表示 ,每 个 步骤 用 一 个 WizardStep 类 
对 象 表示 ,所 以 WizardSteps 属性 是 WizardStep 类 对 象 的 集合 (实际 上 ,WizardSteps 属性 是 
WizardStepBase 类 对 象 的 集合 .而 由 WizardStepBase 类 派生 出 WizardStep 类 ) 。 
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表 6. 27 Wizard 控件 的 常用 属性 和 事件 


类 型 名 称 说 明 
ActiveStep 获取 WizardSteps 集合 中 当前 显示 给 用 户 的 步骤 
CellPadding 获取 或 设置 单元 格 内 容 和 单元 格 边 框 之 间 的 空间 量 
CellSpacing 获取 或 设置 单元 格 间 的 空间 量 
FinishCompleteButtonImageUrl | 获取 或 设置 为 “完成 ”按钮 显示 的 图 像 的 URL 
FinishCompleteButtonText 获取 或 设置 为 “完成 ”按钮 显示 的 文本 标题 
FinishPreviousButtonImageUrl | 获取 或 设置 为 Finish 步骤 中 的 “上 一 步 按 钮 显示 的 图 像 的 URL 
FinishPreviousButtonText 获取 或 设置 为 Finish 步骤 中 的 “上 一 步 ? 按 钮 显示 的 文本 标题 
StartNextButtonJmageUrl 获取 或 设置 为 Start 步骤 中 的 “下 一 步 " 按 钮 显示 的 图 像 的 URL 
属性 | StartNextButtonText 获取 或 设置 为 Start 步骤 中 的 “下 一 步 按 钮 显示 的 文本 标题 
StepNextButtonlmageUrl 获取 或 设置 为 "下 一 步 按 钮 显示 的 图 像 的 URL 
StepNextButtonText 获取 或 设置 为 “下 一 步 按 钮 显示 的 文本 标题 
StepPreviousButtonImageUrl ”| 获取 或 设置 为 “上 一 步 显 示 的 图 像 的 URL 
StepPreviousButtonText 获取 或 设置 为 "上 一 步 按 钮 显示 的 文本 标题 
StepStyle 获取 一 个 对 Style 对 象 的 引用 ,该 对 象 定 义 WizardStep 对 象 的 设置 
HeaderText 获取 或 设置 为 在 控件 上 的 标题 区 域 显 示 的 文本 标题 
HeaderStyle 获取 一 个 对 Style 对 象 的 引用 ,该 对 象 定义 控件 上 标题 区 域 的 设置 
WizardSteps 获取 一 个 包含 为 该 控件 定义 的 所 有 WizardStepBase 对 象 的 集合 
ActiveStepChanged 当 用 户 切 换 到 控件 中 的 新 步骤 时 发 生 
CancelButtonClick 当 单 击 * 取 消 ?按钮 时 发 生 
FinishButtonClick 当 单 击 * 完 成 ”按钮 时 发 生 
事件 NextButtonClick 当 单 击 * 下 一 步 ? 按 钮 时 发 生 
PreviousButtonClick 当 单 击 * 上 一 步 " 按 钮 时 发 生 
SideBarButtonClick 当 单 击 侧 栏 区 域 中 的 按钮 时 发 生 
Wizard 控件 一 次 显示 一 个 WizardStep 对 象 ,用 户 可 以 使 用 Wizard 控件 及 其 相关 联 的 
WizardStep 对 象 以 线性 或 非 线性 方式 收集 相关 数据 。 
用 户 可 以 使 用 WizardSteps 集合 以 编程 方式 访问 包含 在 Wizard 控件 中 的 WizardStepBase 对 


象 .使 用 Add Remove 、Clear 和 Insert 方法 可 以 以 编程 方式 操作 该 集合 中 的 WizardStepBase 


对 象 。 


Wizard 控件 的 所 有 步骤 一 般 是 由 4 个 区 组 成 ,如 图 6. 34 所 示 是 一 个 步骤 的 构成 ,各 区 的 
说 明 如 下 。 


。 标题 


又 提供 一 致 的 信息 。 


区 (Header) : 位 于 界面 上 方 . 可 以 通过 设置 Wizard. HeaderText 属性 值 为 每 个 步 


。 侧 栏 区 (SideBar) : 位 于 界面 的 左 侧 ,包含 所 有 步骤 的 列表 , Wizard 控件 的 所 有 步骤 都 
3 47 < (Header) 
学 号 : 
侧 栏 区 姓名 :- 一 一 向 导 步 又 区 (Step) 
(SideBar) 


[| 


直 = 皮 | 一 -导航 区 (Navigation) 


图 6.34 Wizard 控件 的 组 成 
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会 显示 侧 栏 区 。 

。 向 导 步 又 区 (Step): 位 于 界面 右 中 部 分 , 侧 栏 区 中 的 每 个 列表 对 应 一 个 向 导 步 又 区 ,用 
于 放置 所 需 的 控件 ,以 完成 该 步骤 的 功能 。Wizard 控件 的 每 个 步骤 可 能 不 同 ,需要 开 
次 大 员 一 一 役 计 、 

。 导航 区 (Navigation) : 位 于 界面 的 右 下 方 ,显示 “上 一 步 ”“ 下 一 步 ”? 和 “完成 ”等 按钮 ， 
用 来 实现 逐步 浏览 功能 ,开发 人 员 一 般 不 需要 改变 它 。 

当 向 网 页 中 放置 一 个 Wizard 控件 时 ,初始 界面 如 图 6. 35 所 示 , 侧 栏 区 只 显示 “Stepl1” 和 
“Step2”。 用 户 可 以 通过 “自动 套用 格式 ”命令 设置 其 外 观 ,例如 设置 为 “专业 型 "格式 。 在 属性 
窗口 中 单 击 WizardSteps 属性 后 的 国 按 钮 ,将 弹出 一 个 “WizardStep 集合 编辑 器 ”对 话 框 ,可 
以 添加 和 删除 侧 栏 区 中 的 列表 项 ,如 图 6. 36 所 示 。 


Wizardstep 全 SRS 
提出 尾 性 (P): 
国 %|» 


转 绕 为 SideBarTemplate 
沪 乌 机 板 


图 6.35 Wizard 控件 的 初始 界面 图 6.36 “WizardStep 集合 编辑 器 ”对 话 框 


侧 栏 区 中 的 每 个 列表 项 都 对 应 一 个 向 导 步 又 区 , 单 击 某 个 列表 项 ,对 应 的 向 导 步 又 区 为 
空 , 可 以 向 其 中 放置 所 需 的 控件 。 

标题 区 的 样式 (前 背景 颜色 .字体 大 小 等 ) 通 过 HeaderStyle 属性 设置 ; 侧 栏 区 的 样式 通 
过 SideBarStyle 属性 设置 ; 向 导 步 骤 区 的 样式 通过 StepStyle 属性 设置 ; 导航 区 的 样式 通过 
NavigationStyle 属性 设置 。 

【 例 6.13】 在 ch6 网 站 中 设计 一 个 WebForml3 网 页 ,其 功能 是 说 明 Wizard 控件 的 使 用 
方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch6 网 站 ,选择 “网 站 | 添加 新 项 "命令, 出现 “添加 新 项 -ch6” 对 话 框 ,在 中 间 列 表 中 
选择 “Web 窗 体 ”, 将 文件 名 称 改 为 WebForml3. aspx, 其 他 保持 默认 项 . 单 击 “ 添 加 ”按钮 。 

@ 在 本 网 页 中 添加 一 个 Wizard 控件 ,将 其 “自动 套用 格式 ”设置 为 “专业 型 "格式 ,设置 其 
字体 大 小 为 lem。 

@ 通过 “WizardStep 集合 编辑 器 ”对话 框 在 侧 栏 区 中 设置 3 个 列表 项 “输入 信息 ”步骤 区 
的 设计 界面 如 图 6. 37 所 示 ,其 中 主要 有 两 个 文本 框 (TextBoxl 和 TextBox2) 和 两 个 命令 按钮 
(Buttonl 和 Button2) 。 

@ 单 击 侧 栏 区 中 的 “输出 信息 ”列表 项 ,其 步骤 区 的 设计 界面 如 图 6. 38 所 示 , 其 中 只 有 一 
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个 标签 Labell 。 


[4] <asp:Button.auto-style3#8..> 上 


<asp:Button.auto-style3#B...> 
图 6.37 WebForml3 网 页 设计 界面 一 图 6.38 WebForml3 网 页 设计 界面 二 


@ 单 击 侧 栏 区 中 的 “退出 ?列表 项 ,其 步骤 区 的 设计 界面 如 图 6. 39 所 示 , 其 中 只 有 一 个 
HTML 标签 。 在 本 网 页 上 设计 如 下 事件 过 程 : 


protected void Button1_Click(object sender, EventArgs e) 
{ V/A" 提交" 命令 按钮 的 单 击 事件 过 程 
Labell. Text = "姓名 : " + TextBoxl. Text + "<br>"; 
Labell. Text += "年 龄 : " + TextBox2. Text; 
} 
protected void Button2_Click(object sender, EventArgs e) 
{ 。 //" 重 置 "命令 按钮 的 单 击 事件 过 程 
TextBox1l.Text = ""; 
TextBox2. Text = ""; 


设计 | 日 拆 分 |。 源 | [4][<asp:Buttonauto-style3#6-.> ol 


图 6.39 WebForml3 网 页 设计 界面 三 


最 后 ,本 网 页 中 的 Wizard 控件 Wizardl 对 应 的 HTML 代码 如 下 : 


<asp:Wizard ID = "Wizardl”runat = "server”HeaderText = "学 生 信 ActiveStepIndex = " 
BackColor = " 提 F7F6F3" BorderColor = " 划 CCCCCC" BorderStyle= "Solid" BorderWidth = "1px" 
Font - Names = "Verdana" Font ~ Size= "lem" Height = "166px" Width= "428px"” 
style= "text ~ align: center"> 
< HeaderStyle BackColor = "#5D7B9D" BorderStyle = "Solid" Font ~ Bold= "True" 
Font - Size = "0. 9em" ForeColor = "White" HorizontalAlign = "Center" /> 
< NavigationButtonStyle BackColor = "#FFFBFF" BorderColo 井 CCCCCC" 
BorderStyle = "Solid" BorderWidth= "1px”Font ~ Names = "Verdana" 
Font - Size = "0. 8em" ForeColor = "#284775" /> 
< SideBarButtonStyle BorderWidth = "0px" Font — Names = "Verdana" ForeColor = "White" /> 
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< SideBarStyle BackColor = "#7C6F57" BorderWidth = "0px" Font — Size= "0.9em" 
VerticalAlign = "Top" /> 
< StepStyle BorderWidth = "0px" ForeColor = " 间 #5D7B9D" /> 
<WizardSteps > 
<asp:WizardStep runat = "server" title= "输入 信息 "> 
<div class = "auto- stylel"> 学 号 : 
<asp:TextBox ID = "TextBox1" runat = "server"” Width= "111px"></asp:TextBox> 
姓名 : 
<asp:TextBox ID = "TextBox2" runat = " server" Width= "111px"></asp:TextBox> 
<asp:Button ID = "Button1”runat = "server" CssClass = "auto 一 style3" 
OnClick = "Buttonl_Click" Text = "提交 " /> 
<asp:Button ID = "Button2" runat = "server" CssClass = "auto - style3" 
OnClick = "Button2_Click" Text = " 重 置 " /> 
</div> 
</asp:WizardStep > 
<asp:WizardStep runat = "server" title = "输出 信息 "> 
<div class = "auto - style3"> 
<asp:Label ID = "Labell" runat = "server" style= "color: 井 FEF0OFF; font- size: 
medium; font - weight: 700; font- family: Rrial"></asp:Label > 
</div> 
</asp:WizardStep > 
<asp:WizardStep runat = "server" Title= "退出 "> 
<div class = "auto - style3"> 
< span class = "auto - style4"> 欢 迎 下 次 使 用 </span > 
</div> 
</asp:WizardStep > 
</WizardSteps > 
</asp:Wizard> 


@ 单 击 工 具 栏 中 的 Pp Internet Explorer 按钮 运行 本 网 页 ,选择 侧 栏 区 的 “输入 信息 ?列表 项 , 输 
入 学 号 和 姓名 ,如 图 6. 40 所 示 , 然 后 单 击 * 提 交 ?” 命 令 按钮 。 选 择 侧 栏 区 的 “显示 信息 ?列表 项 
(或 单 击 导航 区 的 “下 一 步 "按钮 ) ,其 结果 如 图 6. 41 所 示 。 其 他 步骤 的 操作 与 此 相似 。 


| - 


CD [EB pwoanosseszaweromlaarp © re oY | hpnocalhosts6528/ WebForml3.asF P ~ © 
x 


图 6.40 ”WebForm13 网 页 运行 界面 一 图 6.41 WebForml3 网 页 运行 界面 二 


练习 题 6 


1. 简 述 Web 标准 服务 器 控件 的 作用 。 
2. 简 述 Web 标准 服务 器 控件 的 分 类 。 
3. 简 述 向 网 页 中 添加 Web 标准 服务 器 控件 的 各 种 方法 。 


oo ~ 加 辐 心 
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. 简 述 TextBox 控件 的 TextMode 属性 的 设置 方法 。 
. 简 述 Button 控件 的 常用 事件 。 


简 述 将 一 个 Button 按钮 设计 成 Command( 命 令 ) 按 钮 的 基本 方法 。 


. 简 述 Button 控件 和 LinkButton、ImageButton 及 HyperLink 控件 的 异同 。 
. 简 述 DropDownList、ListBox、CheckBoxList、RadioButtonList 和 BulletedList 控件 在 


设置 Items 属性 上 的 异同 。 


和 


10. 
二 
12. 
13. 
14. 


举例 说 明 ImageMap 控件 的 应 用 场合 。 
简 述 CheckBox 控件 和 RadioButton 控件 在 功能 上 的 差别 。 
简 述 Table 控件 的 作用 。 
简 述 HiddenField 控件 的 作用 。 
简 述 FileUpload 控件 的 使 用 方法 。 
举例 说 明 View 控件 和 MultiView 控件 的 应 用 场合 。 


上 机 实验 题 6 


在 ch6 网 站 中 添加 一 个 名 称 为 Experment6 的 网 页 ,用 于 输入 学 生 的 学 号 、 姓 名 ,性别 和 
班 号 ,性 别 从 单 选 按钮 中 选择 , 班 号 从 DropDownList 控件 中 选择 。 当 输入 成 功 后 单 击 “ 确 定 ” 
命令 按钮 时 在 Label 控件 中 显示 输入 的 信息 ,用 户 单 击 * 重 置 ” 命 令 按钮 时 实现 输入 重 置 功能 。 
其 运行 界面 如 图 6. 42 所 示 。 


ry 


2 | 
[Breconsess D> ©] Oy Oe weeeononsss po- ca| 
* 画 | 


学 号 
姓名 
性 草 


班 号 
国治 区 到 


输入 信息 : 
学 号 :201 姓名: 王 教 
性 别 : 男 ”尊号 :1502 


图 6.42 上 机 实验 题 6 网 页 的 运行 界面 
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在 Web 应 用 中 ,经 常会 使 用 表单 来 获取 用 户 的 数据 ,如 注册 信息 。 为 了 防 
止 垃圾 信息 ,需要 进行 数据 的 检验 和 过 滤 。 为 此 ,ASP.NET 提供 了 验证 控件 ， 
它们 是 服务 器 控件 ,用 于 实现 客户 端 数据 的 各 种 验证 。 本 章 介绍 ASP.NET 验 
证 控件 的 使 用 方法 。 

本 章 学 习 要 点 : 

回 掌握 ASP.NET 验证 控件 的 特点 。 

加 掌握 各 种 ASP.NET 验证 控件 的 使 用 方法 。 

回 灵 活 地 使 用 各 种 ASP.NET 验证 控件 实现 较 复 杂 网 页 的 设计 。 


7.1 验证 控件 概述 


在 ASP.NET 中 提供 了 6 种 数据 验证 控件 , 它 [EE | 


们 位 于 工具 箱 的 “验证 ”类 别 中 ,如 图 7.1 所 示 。 其 i 
入 ”CompareValidator 
中 ,ValidationSummary 控件 (从 WebControl 类 派 局 CustomValidator 
生 ) 用 于 在 一 个 位 置 向 用 户 显示 所 有 验证 错误 ,其 余 让 
5 个 控件 (都 是 从 BaseCompareValidator 类 派生 的 ) 网 RequiredFieldValidator 
用 来 执行 实际 的 有 效 性 验证 ,如 范围 检查 或 模式 匹 Deore 
配 验 证 控件 。 图 7.1 ASP.NET 提供 的 
、 验证 控件 
7.1.1 使 用 验证 控件 的 方法 
1. 使 用 验证 控件 


通过 像 添 加 其 他 服务 器 控件 那样 向 网 页 添加 验证 控件 , 即 可 启用 对 用 户 输 
入 的 验证 。 每 个 验证 控件 都 引用 网 页 上 其 他 地 方 的 输入 控件 (服务 器 控件 ) 。 
在 处 理 用 户 输入 时 (例如 当 提 交 页 面 时 ) ,验证 控件 会 对 用 户 输入 进行 测试 ,并 
设置 属性 以 指示 该 输入 是 否 通过 测试 。 在 调用 了 所 有 验证 控件 后 ,会 在 网 页 上 
设置 一 个 属性 以 指示 是 否 出 现 验证 检查 失败 。 

用 户 可 以 使 用 自己 的 代码 来 测试 网 页 和 单个 控件 的 状态 。 例 如 ,使 用 用 户 
输入 信息 更 新 数据 记录 之 前 来 测试 验证 控件 的 状态 。 如 果 检 测 到 状态 无 效 , 将 
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会 略 过 更 新 。 通 常 ,如 果 任 何 验证 检查 失败 ,都 将 跳 过 所 有 处 理 过 程 并 将 网 页 返回 给 用 户 。 检 
测 到 错误 的 验证 控件 随后 将 生成 显示 在 网 页 上 的 错误 信息 。 用 户 也 可 以 将 验证 控件 关联 到 验 
证 组 中 ,使 得 属于 同一 组 的 验证 控件 可 以 一 起 进行 验证 。 

默认 情况 下 ,在 单 击 按钮 控件 (如 Button .ImageButton 或 LinkButton) 时 执行 验证 ,可 通 
过 将 按钮 控件 的 CausesValidation 属性 设置 为 False 来 禁止 在 单 击 按钮 控件 时 执行 验证 。 

2. 何 时 进行 验证 

验证 控件 在 服务 器 代码 中 执行 输入 检查 。 当 用 户 向 服务 器 提交 网 页 之 后 ,服务 器 将 逐个 
调用 验证 控件 来 检查 用 户 输入 。 如 果 在 任意 输入 控件 中 检测 到 验证 错误 , 则 该 网 页 将 自行 设 
置 为 无 效 状态 ,以 便 在 代码 运行 之 前 测试 其 有 效 性 。 验 证 发 生 的 时 间 是 已 对 网 页 进行 了 初始 
化 ( 即 处 理 了 视图 状态 和 回 发 数据 ) ,但 尚未 调用 任何 更 改 或 单 击 事件 处 理 程序 。 

3. 验证 多 个 条 件 

每 个 验证 控件 通常 只 执行 一 次 测试 ,但 有 时 需要 指定 多 个 条 件 , 例 如 指定 某 个 日 期 文本 框 
必须 输入 数据 ,同时 将 该 用 户 输 入 限制 为 只 接受 特定 范围 内 的 日 期 。 

此 时 可 以 将 多 个 验证 控件 附加 到 网 页 上 的 一 个 输入 控件 。ASP.NET 使 用 逻辑 AND 
运算 符 来 解析 控件 执行 的 测试 ,这 意味 着 用 户 输入 的 数据 必须 通过 所 有 测试 才能 被 视 为 
有 效 。 

在 有 些 情 况 下 , 几 种 不 同 格式 的 输入 都 可 能 是 有 效 的 。 例 如 ,在 提示 输入 电话 号 码 时 允许 
用 户 输 入 本 地 号 码 ,长途 号 码 或 国际 长 途 号 码 。 若 要 执行 此 类 测试 (必须 仅 通过 一 个 测试 的 逻 
辑 OR 运算 ) ,可 以 使 用 RegularExpressionValidator 验证 控件 并 在 该 控件 中 指定 多 个 有 效 模 
式 , 或 者 使 用 CustomValidator 验证 控件 并 编写 自己 的 验证 代码 。 


7.1.2 验证 控件 的 公共 属性 和 方法 


所 有 验证 控件 都 具有 服务 器 控件 的 一 些 常用 属性 ,另外 ,5 个 ASP.NET 有 效 性 验证 控件 
都 有 一 些 如 表 7. 1 所 示 的 公共 属性 ,正确 地 设置 这 些 公共 属性 是 使 用 验证 控件 的 关键 。 


表 7.1 验证 控件 的 公共 属性 


属 性 说 明 
ControlToValidate ”获取 或 设置 要 验证 的 输入 控件 的 ID 
Display 获取 或 设置 验证 控件 中 错误 信息 的 显示 行为 ,其 取 值 如 表 7. 2 所 示 


EnableClientScript ”指示 是 否 启用 客户 端 验证 。 通 过 将 EnableClientSeript 属性 设置 为 False, 可 在 支持 此 
功能 的 浏览 器 上 禁用 客户 端 验证 

ErrorMessage 获取 或 设置 验证 失败 时 ValidationSummary 控件 中 显示 的 错误 消息 的 文本 ,此 属性 不 
会 将 特殊 字符 转换 为 HTML 实体 。 例 如 ,小 于 号 字符 (二 ) 不 转换 为 &&lt; 。 这 人 允许 将 
HTML 元 素 ( 如 一 img 元 素 ) 嵌 入 到 该 属性 的 值 中 

IsValid 获取 或 设置 一 个 值 ,该 值 指示 关联 的 输入 控件 是 否 通过 验证 

Text 获取 或 设置 验证 失败 时 验证 控件 中 显示 的 文本 

ValidationGroup 获取 或 设置 此 验证 控件 所 属 的 验证 组 的 名 称 


每 个 验证 控件 都 对 应 一 个 需要 验证 其 输入 值 的 输入 控件 ,如 TextBox 控件 ,验证 控件 的 
ControlToValidate 属性 就 设置 为 这 个 输入 控件 的 ID。 

如 果 输 入 控件 的 值 通过 了 验证 ,验证 控件 的 IsValid 为 True, 否则 为 False。Page. 
IsValid 为 True 表示 该 网 页 的 所 有 控件 都 通过 了 验证 ,否则 Page. IsValid 为 False。 
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使 用 Display 属性 指定 验证 控件 中 错误 信息 的 显示 行为 ,显示 行为 取决 于 是 否 执行 客户 
端 验证 。Display 属性 如 表 7. 2 所 示 。 如 果 客 户 端 验 证 不 是 活动 的 (由 于 浏览 器 不 支持 它 等 情 
况 ), 则 Static 和 Dynamic 的 行为 相同 , 即 错误 信息 仅 在 显示 时 才 占 用 空间 ,在 错误 信息 不 显示 
(Static) 时 为 其 动态 分 配 空间 的 功能 只 对 客户 端 验 证 适用 。 
表 7.2 Display 属性 的 取 值 及 其 说 明 


显示 行为 取 值 说 明 
None 指定 只 想 在 ValidationSummary 控件 中 显示 错误 信息 。 错 误 信 息 不 会 显示 在 验证 控件 中 
Static 指定 不 希望 网 页 的 布局 在 验证 程序 控件 显示 错误 信息 时 改变 。 显 示 页 面 时 将 在 页 面 上 为 


错误 信息 分 配 空间 ,验证 程序 的 内 容 是 页 面 的 物理 组 成 部 分 ,因此 ,同一 输入 控件 的 多 个 
验证 程序 必须 在 页 面 上 占据 不 同 的 位 置 

Dynamic 指定 希望 在 验证 失败 时 在 网 页 上 动态 放置 错误 信息 。 由 于 页 面 上 没有 为 验证 内 容 分 配 的 
空间 ,因此 页 面 动 态 更 改 以 显示 错误 信息 


当 同 时 使 用 Text 和 ErrorMessage 属性 时 ,在 发 生 错误 时 将 显示 Text 属性 的 信息 。 
5 个 有 效 性 验证 控件 都 有 Validate 方法 ,该 方法 对 关联 的 输入 控件 执行 验证 并 更 新 
IsValid 属性 。 


7.2 常见 的 验证 控件 
7.2.1 RequiredFieldvalidator 控件 


RequiredFieldValidator 控件 又 称 为 非 空 验证 控件 ,对 应 命名 空间 System. Web. UL. 
WebControls 中 的 RequiredFieldValidator 类 。 该 控件 常用 于 文本 框 数据 的 非 空 验证 ,确保 用 
户 在 网 页 上 输入 数据 时 不 会 跳 过 必 选 字段 (必须 输入 数据 的 字段 ) ,也 就 是 说 检查 被 验证 控件 
的 输入 是 否 为 空 , 如 果 为 空 , 则 在 网 页 中 显示 提示 信息 。 

除了 公共 属性 外 .RequiredFieldValidator 控件 还 有 一 个 重要 的 属性 InitialValue, 它 获取 
或 设置 关联 的 输入 控件 的 初始 值 。 如 果 输 入 控件 失去 焦点 时 没有 从 InitialValue 属性 更 改 值 ， 
它 将 不 能 通过 验证 。 

【 例 7.1】 在 D 盘 ASP.NET 目录 中 建立 一 个 ch7 的 子 目录 ,将 其 作为 网 站 目录 ,然后 创 
建 一 个 WebForml 网 页 ,其 功能 是 说 明 RequiredFieldValidator 控件 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012 。 

@ 选择 “文件 | 新 建 | 网 站 ”命令 .出 现 * 新 建 网 站 "对话 框 , 然 后 选择 “ASP.NET 空 网 站 ” 
模板 ,选择 “Web 位 置 "为 “文件 系统 ”, 单 击 “ 浏 览 ” 按 钮 ,选择 “D:\ASP.NET\ch7” 目 录 , 单 击 
“确定 ”按钮 ,创建 一 个 空 的 网 站 ch7。 

@ 选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch7” 对 话 框 ,在 中 间 列 表 中 选择 "Web 窗 
体 页 ”, 将 文件 名 称 改 为 WebForml. aspx, 其 他 保持 默认 项 , 单 击 “ 添 加 ”按钮 。 

@ 进入 设计 视图 ,设计 本 网 页 界面 如 图 7. 2 所 示 , 其 中 有 两 个 文本 框 (TextBoxl 和 
TextBox2) ,一 个 命令 按钮 Button1. 一 个 标签 Labell 和 两 个 RequiredFieldValidator 控件 。 
将 RequiredFieldValidatorl 控件 的 ControlToValidate 属性 设置 为 TextBoxl.Text 属性 设置 
为 “学 号 必须 输入 ”; 将 RequiredFieldValidator2 控件 的 ControlToValidate 属性 设置 为 
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TextBox2,Text 属性 设置 为 “姓名 必须 输入 ”。 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Page Load( object sender, EventArgs e) 
{ 
RequiredFieldValidatorl. InitialValue = "106"; 
和 
protected void Button1l_Click(object sender, EventArgs e) 
{ if (Page. IsValid) 
Labell.Text = "输入 通过 了 验证 "; 
else 
Labell.Text = "输入 没有 通过 验证 "; 
} 
其 中 ,if (Page. IsValid) 可 以 用 if (RequiredFieldValidatorl. IsValid) 等 价 地 替代 ,因为 该 
网 页 上 只 有 RequiredFieldValidatorl 一 个 验证 控件 。 
@ 单 击 工 具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,输入 学 号 106, 单 击 “ 提 交 ” 命 令 按 
钮 ,其 结果 如 图 7. 3 所 示 。 因 为 输入 的 学 号 与 RequiredFieldValidatorl 控件 的 InitialValue 值 
相同 ,而 姓名 没有 输入 ,所 以 两 个 验证 控件 都 没有 验证 成 功 。 此 时 尽管 Page. IsValid 为 False， 
但 将 跳 过 所 有 处 理 过 程 ,所 以 不 会 执行 Button1_Click 事件 处 理 过 程 , 在 Labell 中 显示 “输入 


RequiredFieldValidatorl 控件 


姓名 : 姓名 必须 输入 
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[Label1] 


手 号 :| 学 号 必须 险 入 | | 


RequiredFieldValidator2 控件 


图 7.2 WebForml 网 页 设计 界面 图 7.3 WebForml 网 页 运行 界面 一 


如 果 输 入 学 号 108, 输 入 姓名 “ 王 华 ”, 单 击 “ 提 交 ” 命 
令 按 钮 ,其 结果 如 图 7.4 所 示 , 所 有 验证 控件 都 通过 验 
证 。Page. IsValid 为 True, 并 执行 Buttonl _Click 事件 
处 理 过 程 ,在 Labell 中 显示 “输入 通过 了 验证 ”。 

注意 : 由 于 本 例 将 RequiredFieldValidatorl 控件 的 
InitialValue 值 设置 为 106, 只 有 输入 学 号 为 106 时 才 验 
证 失败 ,其 他 任何 值 即 使 为 空 也 会 验证 成 功 , 所 以 该 属性 
设置 需要 根据 实际 情况 而 定 。 

提示 : 如 果 包 含有 验证 控件 的 网 页 在 IE 浏览 器 中 
运行 时 出 现 如 下 错误 。 国 全 人 故人 6 网 大生 条 守 丙 一 


WebForms UnobtrusiveValidationMode 需要 "jquery”ScriptResourceMapping. 请 添加 一 个 名 为 jquery 
(区 分 大 小 写 ) 的 ScriptResourceMapping 


其 错误 原因 是 因为 采用 Visual Studio 2012( 或 2013) 开 发 基于 ASP.NET 4.5 的 Web 应 用 程 
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序 时 很 多 控件 默认 允许 了 Unobtrusive ValidationMode( 一 种 隐 式 的 验证 方式 ) 的 属性 , 它 与 
jquery 的 引用 相关 ,但 并 未 对 其 进行 赋值 ,程序 员 必 须 手动 对 其 进行 设置 。 
一 种 简单 的 解决 方法 就 是 将 该 属性 设置 为 None, 可 以 在 网 站 的 Web. config 文件 中 添加 
如 下 部 分 达到 这 一 目的 。 
<appSettings > 
<add key = "ValidationSettings:UnobtrusiveValidationMode" value= "None" /> 
</appSettings > 
实际 上 ,用 户 也 可 以 使 用 浏览 器 支持 的 客户 端 脚 本 执行 验证 ,这 样 可 以 缩短 网 页 的 响应 时 
间 , 因 为 错误 将 被 立即 检测 到 并 且 将 在 用 户 离 开 包 含 错误 的 控件 后 立即 显示 错误 信息 。 如 果 
可 以 进行 客户 端 验证 ,将 可 以 在 很 大 程度 上 控制 错误 信息 的 布局 并 可 以 在 消息 框 中 显示 错误 
摘要 。 
验证 控件 可 与 ASP.NET 网 页 上 的 任何 控件 (包括 HTML 和 Web 服务 器 控件 ) 一 起 使 
用 。 验 证 控件 在 客户 端 上 呈现 的 对 象 模 型 与 在 服务 器 上 呈现 的 对 象 模型 几乎 完全 相同 。 例 
如 ,无 论 在 客户 端 上 还 是 在 服务 器 上 都 可 以 通过 相同 的 方式 读 取 验证 控件 的 IsValid 属性 以 
测试 验证 。 但 是 在 页 级 别 上 公开 的 验证 信息 有 所 不 同 。 在 服务 器 上 网 页 支持 Page 的 验证 属 
性 ,在 客户 端 包 含 相应 的 验证 全 局 变量 , 表 7.3 给 出 了 它们 的 对 应 关系 。 
注意 : 所 有 与 Page 相关 的 验证 信息 都 应 被 视 为 只 读 信 息 。 
表 7.3 客户 端 页 变量 和 服务 器 Page 属性 的 对 应 关系 
客户 端 中 的 验证 变量 服务 器 中 Page 的 验证 属性 
Page_lsValid lsValid 
Page_Validators( 数 组 ) 包 含 对 页 上 所 有 验证 控件 的 引用 Validators( 集 合 ) 包 含 对 所 有 验证 控件 的 引用 
Page_ValidationActive 表示 是 否 应 进行 验证 的 布尔 值 。 通 ”无 等 效 项 
过 编程 方式 将 此 变量 设置 为 False 以 关闭 客户 端 验证 


下 面 介绍 一 个 验证 控件 在 客户 端 上 呈现 的 示例 ,其 功能 与 例 7. 1 相似 ,可 以 看 出 验证 控件 
在 服务 器 和 客户 端 上 呈现 时 编程 方式 的 不 同 。 

【 例 7.2】 在 ch? 网 站 中 设计 一 个 WebForm2 网 页 ,其 功能 是 说 明 验 证 控件 在 客户 端 中 
的 使 用 方法 。 
解 : 其 步骤 如 下 。 


Pe TF @ 打开 ch7 网 站 ,选择 “网 站 | 添加 新 项 "命令 , 添 
和 ”加 一 个 文件 名 称 为 WebForm2. aspx 的 单 文件 模型 的 
姓名 : [而 入 一 个 竹 名 姓名 必须 输入 | 网 页 
和 | @ 本 网 页 的 设计 界面 如 图 7.5 所 示 , 其 中 “提交 ” 
| 别 命令 按钮 是 一 个 HTML 控件 Button1( 对 应 工具 箱 中 
| mm 下 ”HTML 类 别 的 input(Button) 控 件 ), 下 方 的 文本 框 
设计 |e 折 分 |。 源 | [4] <aspTextBoxsTexnt | 


Textl 也 是 一 个 HTML 控件 (对 应 工具 箱 中 HTML 
图 7.5 WebForm2 网 页 设计 界面 类别 的 input(Text) 控 件 ) ,它们 都 是 客户 端 控件 ,对 应 
的 HTML 代码 如 下 : 


< input id = "Button1” type= "button" value= "提交 " onclick = "valid()" /> 
<input id = "Text1" type = "text" aria- readonly = "True" /><br /> 
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其 他 控件 及 其 属性 设置 与 WebForml 网 页 的 相同 ,只 是 给 两 个 要 验证 输入 的 文本 框 
TextBoxl 和 TextBox2 设置 了 初始 值 。 
@ 在 该 网 页 上 增加 如 下 JavaScript 脚本 : 


< script type = "text/javascript"> 
function valid() 
{ if (Page IsValid) 
forml.Text1. value = "输入 通过 了 验证 "; 
else 


forml.Textl.value = "输入 没有 通过 验证 "; 


} 


</script> 
其 中 ,Page_IsValid 是 客户 端 全 局 变量 , 当 网 页 在 客户 端 运行 时 存在 任何 验证 问题 , 它 的 
值 为 False。 


@ 单 击 工 具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,修改 “学 号 "文本 框 的 值 为 110“ 姓 
名 "文本 框 的 值 为 " 李 明 ”, 单 击 * 提 交 ” 命 令 按 钮 ,其 结果 如 图 7.6 所 示 ,表示 通过 了 验证 。 继 续 
运行 ,将 “学 号 ”文本 框 清空 , 单 击 " 提 交 ” 命 令 按 钮 ,其 结果 如 图 7.7 所 示 ,表示 没有 通过 验证 。 


© 


学 号 必须 输入 


大 hapy/localhost5534 只 - 上 
x 


输入 通过 了 验证 | | 输入 没有 通过 验证 


图 7.6 WebForm2 网 页 运行 界面 一 图 7.7 WebForm2 网 页 运行 界面 二 


从 上 例 看 到 ,验证 控件 虽然 是 服务 器 控件 ,也 可 以 在 客户 端 提供 验证 功能 。 如 果 关 闭 要 验 
证 控件 的 这 种 客户 端 验 证 功能 ,可 以 将 其 EnableClientScript 设置 为 False。 例 如 ,以 下 代码 用 
于 关闭 RequiredFieldValidatorl 控件 的 客户 端 验证 功能 : 

RequiredFieldValidatorl. EnableClientScript = False; 

也 可 以 使 用 以 下 代码 关闭 网 页 上 所 有 验证 控件 的 客户 端 验证 功能 : 


foreach( BaseValidator bv in Page. Validators) 
bv. EnableClientScript = False; 


这 个 foreach 循环 首先 找到 ASP .NET 网 页 包含 的 验证 器 中 的 每 个 BaseValidator 对 象 
(验证 控件 都 是 从 BaseValidator 类 派生 的 ) ,然后 关闭 它 的 客户 端 验证 功能 。 


7.2.2 CompareValidator 控件 


CompareValidator 控件 又 称 比较 验 证 控件 ,对 应 命名 空间 System. Web. UL WebControls 中 

的 CompareValidator 类 。 该 控件 将 用 户 的 输入 与 常数 值 (由 ValueToCompare 属性 指定 )、 另 

个 控件 (由 ControlToCompare 属性 指定 ) 的 属性 值 进行 比较 , 若 不 相同 , 则 在 网 页 中 显示 提 
示 信 息 。 
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除了 公共 属性 外 ,CompareValidator 控件 的 其 他 重要 的 属性 如 表 7.4 所 示 。 
使 用 Operator 属性 指定 要 执行 的 比较 操作 ,如 大 于 、 等 于 等 ,其 基本 取 值 如 表 7. 5 所 示 。 
如 果 设 置 Type 属性 , 则 在 比较 操作 前 将 两 个 比较 值 都 自动 转换 为 Type 属性 指定 的 数据 类 
型 ,然后 进行 比较 ,如 表 7.6 所 示 。 
通常 不 要 同时 设置 ControlToCompare 和 ValueToCompare 属性 ,但 如 果 同 时 设置 这 两 
个 属性 , 则 ControlToCompare 属性 优先 。 
表 7.4 CompareValidator 控件 的 常用 属性 
属 性 说 明 
ControlToCompare ”获取 或 设置 要 与 所 验证 的 输入 控件 进行 比较 的 输入 控件 
ValueToCompare ”获取 或 设置 一 个 常数 值 , 该 值 要 与 由 用 户 输入 到 所 验证 的 输入 控件 中 的 值 进行 比较 
Operator 获取 或 设置 要 执行 的 比较 操作 
Type 获取 或 设置 在 比较 之 前 将 所 比较 的 值 转换 到 的 数据 类 型 ,其 取 值 如 表 7.6 所 示 


表 7.5 Operator 属性 的 基本 操作 及 其 说 明 


操 作 值 说 明 
Equal 0 ”默认 值 .所 验证 的 输入 控件 的 值 与 其 他 控件 的 值 或 常数 值 之 间 的 相等 比较 
NotEqual 1 ”所 验证 的 输入 控件 的 值 与 其 他 控件 的 值 或 常数 值 之 间 的 不 等 比较 
GreaterThan 2 ”所 验证 的 输入 控件 的 值 与 其 他 控件 的 值 或 常数 值 之 间 的 大 于 比较 
GreaterThanEqual 3 ”所 验证 的 输入 控件 的 值 与 其 他 控件 的 值 或 常数 值 之 间 的 大 于 或 等 于 比较 
LessThan 4 ”所 验证 的 输入 控件 的 值 与 其 他 控件 的 值 或 常数 值 之 间 的 小 于 比较 
hanEqual 5 ”所 验证 的 输入 控件 的 值 与 其 他 控件 的 值 或 常数 值 之 间 的 小 于 或 等 于 比较 


DataTypeCheck 输入 到 所 验证 的 输入 控件 的 值 与 BaseCompareValidator. Type 属性 指定 的 数据 类 
型 之 间 的 数据 类 型 比较 。 如 果 无 法 将 该 值 转换 为 指定 的 数据 类 型 , 则 验证 失败 


表 7.6 Type 属性 的 取 值 及 其 说 明 


数据 类 型 值 说 明 

String 0 指定 字符 串 数据 类 型 

Integer 1 指定 32 位 有 符号 整数 数据 类 型 
Double 2 指定 双 精 度 浮 点 数 数据 类 型 
Date 3 指定 日 期 数据 类 型 

Currency 4 指定 货币 数据 类 型 


【 例 7.3】 在 ch7 网 站 中 设计 一 个 WebForm3 网 页 ,其 功能 是 说 明 CompareValidator 控 
件 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch7 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,添加 一 个 文件 名 称 为 WebForm3. aspx 的 
代码 隐藏 模型 的 网 页 。 

@ 本 网 页 的 设计 界面 如 图 7.8 所 示 , 其 中 有 两 个 文本 框 TextBoxl 和 TextBox2、 两 个 列 
表 框 ListBoxl 和 ListBox2, 一 个 命令 按钮 Buttonl .一 个 标签 Labell 和 一 个 比较 验证 控件 
CompareValidatorl。 

数据 类 型 列表 框 ListBoxl 对 应 的 HTML 代码 如 下 : 


<asp:ListBox ID = "ListBoxl”runat = "server" CssClass = "auto— style5" Width= "137px" 
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OnSelectedIndexChanged = "ListBoxl_SelectedIndexChanged" 
AutoPostBack = " True" Height = "96px"> 

<asp:ListItem Selected= "True"> String </asp:ListItem> 

<asp:ListItem> Integer </asp:ListItem> 

<asp:ListItem> Double </asp:ListItem> 

<asp:ListItem> Date </asp:ListItem> 

<asp:ListItem> Currency </asp:ListItem> 

</asp:ListBox> 


[Label1] | 


| [CompareValidator1] 


4 = » 
设计 |o 拆 分 |。 源 | [4] <asptlistBoxauto-styless-> [>] 


图 7.8 WebForm3 网 页 设计 界面 
比较 操作 列表 框 ListBox2 对 应 的 HTML 代码 如 下 : 


<asp:ListBox ID = "ListBox2" runat = "server" CssClass = "auto - style5" Width = "162px" 
OnSelectedIndexChanged = "ListBox2_SelectedIndexChanged”" 
AutoPostBack = "True" Height = "112px"> 
<asp:ListItem Selected = "True"> Equal </asp:ListItem> 
<asp:ListItem> NotEqual </asp:ListItem> 
<asp:ListItem> GreaterThan </asp:ListItem> 
<asp:ListItem > GreaterThanEqual </asp:ListItem > 
<asp:ListItem> LessThan </asp:ListItem> 
<asp:ListItem > LessThanEqual </asp:ListItem > 
</asp:ListBox> 


比较 验证 控件 CompareValidatorl 对 应 的 HTML 代码 如 下 : 


<asp:CompareValidator ID = "CompareValidator1" runat = "server" 
ControlToCompare = "TextBox2" ControlToValidate = "TextBox1"> 
</asp:CompareValidator > 


@ 在 该 网 页 上 设计 如 下 事件 处 理 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
{ 
Labell. Text = ""; 
} 
protected void Button1_Click(object sender, EventArgs e) 
string mystr = TextBoxl.Text.ToString() + "("+ ListBoxl. SelectedValue.ToString() +") "; 
mystr += ListBox2.SelectedValue.ToString() +" "; 
mystr += TextBox2. Text. ToString() + "(" + ListBoxl.SelectedValue.ToString() + ")"; 
if (Page. IsValid) 
Labell.Text = mystr+ "<br> 验 证 结果 : 有 效 "; 
else 
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Labell.Text = mystr+ "<br> 验 证 结果 : 无 效 "; 
} 
protected void ListBox2_SelectedIndexChanged(object sender, EventArgs e) 
{ CompareValidatorl.Operator = (ValidationCompareOperator)ListBox2. SelectedIndex; 
CompareValidatorl. Validate( ); // 对 关联 的 输入 控件 执行 验证 并 更 新 IsValid 属性 
} 
protected void ListBoxl_SelectedIndexChanged(object sender, EventArgs e) 
{ CompareValidatorl.Type = (ValidationDataTyYpe)ListBox1.SelectedIndex; 
CompareValidator1. Validate( ); // 对 关联 的 输入 控件 执行 验证 并 更 新 IsValid 属性 
} 


说 明 : 由 于 CompareValidatorl 控件 的 Operator 属性 的 取 值 为 ValidationCompareOperator 
类 型 的 枚 举 值 0 一 6, 所 以 要 用 (ValidationCompareOperator) ListBox2. SelectedIndex 给 
CompareValidatorl. Operator 赋值 。CompareValidatorl. Type 也 是 如 此 。 

@ 单 击 工具 栏 中 的 上 Imiemet Explorer 按钮 运行 本 网 页 ,在 " 值 1" 文 本 框 中 输入 “China”, 在 
“ 值 2” 文 本 框 中 输入 *USA”, 在 “数据 类 型 "列表 框 中 选择 String”, 在 “比较 操作 ”列表 框 中 选 
择 “NotEqual”, 单 击 “ 验 证 ”命令 按钮 ,其 结果 如 图 7.9 所 示 。 


入 htpy/ocalhost55340/We P -6 
x 


图 7.9 WebForm3 网 页 运行 界面 


7.2.3 ”RangeValidator 控件 


RangeValidator 控件 又 称 范围 验证 控件 ,对 应 命名 空间 System. Web. UI. WebControls 
中 的 RangeValidator 类 。 该 控件 用 于 确保 用 户 输入 的 值 在 指定 的 上 、 下 限 范围 之 内 , 当 输 入 
的 值 不 在 验证 的 范围 内 时 , 则 在 网 页 中 显示 提示 信息 。 

除了 公共 属性 外 , RangeValidator 控件 的 其 他 重要 的 属性 有 MinimumValue 和 
MaximumValue, 它 们 用 于 指定 要 比较 值 的 范围 。 


7.2.4 RegularExpressionValidator 控件 


RegularExpressionValidator 控件 又 称 正 则 表达 式 验 证 控件 , 它 的 功能 比 非 空 验证 
和 范围 验证 控件 的 功能 更 强大 ,对 应 命名 空间 System. Web. UI. WebControls 中 的 
RegularExpressionValidator 类 。 

除了 具有 验证 控件 的 公共 属性 外 ,RegularExpressionValidator 控件 的 其 他 重要 属性 有 


ValidationExpression ,该 属性 用 于 指定 正则 表达 式 。 


表 7.7 常用 正则 表达 式 字符 及 其 说 明 
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正则 表达 式 由 正则 表达 式 字 符 组 成 , 常 
用 的 正则 表达 式 字 符 及 其 说 明 如 表 7.7 所 示 。 例 如 ,邮政 编码 的 正则 表达 式 为 ^\d{6}”。 


正则 表达 式 字符 说 明 
Ead 匹配 括号 中 的 任何 一 个 字符 
Ess 匹配 不 在 括号 中 的 任何 一 个 字符 
\w 匹配 任何 一 个 字符 (a 一 z、A 一 Z 和 0 一 9) 
\W 匹配 任何 一 个 空白 字符 
\s 匹配 任何 一 个 非 空白 字符 
\S 与 任何 非 单词 字符 匹配 
\d 匹配 任何 一 个 数字 字符 (0 一 9) 
\D 匹配 任何 一 个 非 数字 字符 (^"0 一 9) 
[\b] 匹配 任何 一 个 退 格 键 字 符 
{n,m} 最 少 匹 配 前 面 表达 式 mn 次 ,最 多 为 m 次 
{n,} 最 少 匹 配 前 面 表达 式 n 次 
人 匹配 前 面 表达 式 0 次 或 1 次 {0,1 
十 至 少 匹 配 前 面 表达 式 1 次 {1,} 
关 至 少 匹 配 前 面 表达 式 0 次 {0,} 
| 匹配 前 面 表达 式 或 后 面 表 达 式 
《人 在 单元 中 组 合 项 目 
匹配 字符 串 的 开头 
$ 匹配 字符 串 的 结尾 
\b 匹配 字符 边界 
\B 匹配 非 字符 边界 的 某 个 位 置 


RegularExpressionValidator 控件 用 于 确保 用 
户 输入 的 信息 与 ValidationExpression 属性 指定 的 
正则 表达 式 模式 相 匹配 。 

实际 上 ,Visual Studio 预先 设 好 了 一 些 常用 的 正 
则 表达 式 ,在 属性 窗口 中 单 击 ValidationExpression 属 
性 右 侧 的 圆 按钮 出现 如 图 7. 10 所 示 的 “正则 表达 
式 编辑 器 ?对 话 框 ,其 中 列 出 了 常用 的 正则 表达 式 ， 
从 中 选择 一 个 标准 表达 式 即 可 。 

例如 , 一 个 RegularExpressionValidatorl 用 于 
验证 文本 框 TextBoxl 中 输入 的 “Internet URL” 是 
否 正确 ,对 应 的 HTML 代码 如 下 : 


验证 表达 式 (E);: 
‖ hapltsz?WNwJ+W+NwJ+UCw- /7%8e=1)? 


Ca jC | 


图 7.10 


“正则 表达 式 编辑 器 ”对话 框 


<asp:RegularExpressionValidator ID = "RegularExpressionVal idator1”runat = "server" 
ControlToValidate = "TextBoxl"”ErrorMessage= "URL 错误 ” 
ValidationExpression = "http(s)?://([\w— ] +\.)+[\w-]+(/[\w- ./?% gamp; = ]* )?"> URL 错误 


</asp:RegularExpressionValidator > 


其 中 ,ValidationExpression 属性 是 系统 自动 产生 的 , 它 对 应 “Internet URL” 的 正则 表 


达 式 。 
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7.2.5 ”CustomValidator 控件 


CustomValidator 控件 又 称 自 定义 验证 控件 ,对 应 命名 空间 System. Web. UI. WebControls 中 
的 CustomValidator 类 。 该 控件 确保 用 户 输入 的 内 容 符合 自己 创建 的 验证 逻辑 。 

除了 具有 验证 控件 的 公共 属性 外 ,CustomValidator 控件 具有 重要 的 自 定义 验证 函数 属 
性 。CustomValidator 控件 的 验证 分 为 服务 器 自 定义 验证 和 客户 端 自 定义 验证 。 

对 于 服务 器 自 定义 验证 ,需要 定义 OnServerValidate 属性 (实际 上 是 委托 ) , 即 需 要 为 执 
行 验证 的 ServerValidate 事件 提供 一 个 处 理 过 程 , 该 事件 在 服务 器 上 执行 验证 时 引发 。 
ServerValidate 事件 处 理 过 程 的 格式 如 下 : 


protected void CustomVal idator1_ServerValidate(object source, 
ServerValidateEventArgs args) 


// 代 码 

} 

用 户 可 以 通过 使 用 作为 参数 传递 到 该 事件 处 理 过 程 ServerValidateEventArgs 对 象 ( 即 
args 参数 ) 的 Value 属性 来 访问 要 验证 的 输入 控件 中 的 字符 串 ,然后 将 验证 的 结果 存储 在 
ServerValidateEventArgs 对 象 的 IsValid 属性 中 。 

对 于 客户 端 自 定义 验证 ,需要 定义 ClientValidationFunction 属性 ,该 属性 获取 或 设置 用 
于 验证 的 自 定义 客户 端 脚 本 函数 的 名 称 , 即 为 输入 控件 提供 用 户 定 义 的 验证 函数 。 

【 例 7.4】 在 ch7 网 站 中 设计 一 个 WebForm4 网 页 ,其 功能 是 说 明 CustomValidator 控 
件 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

QO@ 打开 ch7 网 站 ,选择 “网 站 | 添加 新 项 ” 
命令 ,添加 一 个 文件 名 称 为 WebForm4. aspx 


lbody| Ee 


| 用 户 名 : [CustomValidator1] 


| 
的 代码 隐藏 模 型 的 网 页 。 EE | 
@ 本 网 页 的 设计 界面 如 图 7. 11 所 示 , 其 ae | 
中 在 一 个 闪 本 春 ToxtBoxls 一 个 命令 按钮 rh [4] <asp:Buttons#Button1> 站 
Buttonl .一 个 标签 Labell 和 一 个 自 定义 验 证 “人 
控件 CustomValidatorl 。 CustomValidatorl 图 7.11 WebForm4 网 页 设计 界面 


对 应 的 HTML 代码 如 下 : 


<asp:CustomValidator ID = "CustomValidator1”runat = "server" 
ControlToValidate = "TextBox1" CssClass = "auto ~ stylel" 
OnServerValidate = "CustomValidatorl ServerValidate"> 
</asp:CustomValidator > 


@ 在 该 网 页 上 设计 如 下 事件 处 理 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
{ 
Labell. Text = ""; 
} 
protected void CustomVal idator1_ServerValidate(object source, 
ServerValidateEventArgs args) 
{ if (args. Value.ToString() == "1234") 
args.IsValid = True; 


else 
args.IsValid = False; 
} 
protected void Buttonl_ Click(object sender, EventArgs e) 
{ if (!CustomValidator1. IsValid) 
CustomValidatorl. Text = "验证 不 成 功 "; 
else 
Labell. Text = "验证 成 功 "; 
} 


只 有 当 输 入 用 户 名 为 “1234” 时 才 是 正确 的 ,其 他 输入 都 会 导致 CustomValidatorl. 


IsValid 为 False。 


@ 单 击 工具 栏 中 的 > ntemet Explorer 按钮 运行 本 网 页 ,在 “用 户 名 ”文本 框 中 输入 "1234”, 单 
击 “ 提 交 ” 命 令 按钮 ,其 结果 如 图 7. 12 所 示 , 表示 通过 验证 。 在 用户 名 ”文本 框 中 输入 
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“12345”, 单 击 “ 提 交 ” 命 令 按钮 ,其 结果 如 图 7. 13 所 示 , 表 示 验 证 没有 通过 。 


图 7.12 WebForm4 网 页 运行 界面 一 图 7.13 WebForm4 网 页 运行 界面 二 


使 用 CustomValidator 控件 进行 客户 端 验证 与 服务 器 验证 一 样 ,只 是 要 用 
ClientValidationFunction 属性 指定 客户 端的 验证 函数 ,该 函数 需要 两 个 参数 , 即 source 和 
arguments。source 是 对 验证 控件 的 引用 ,arguments 是 一 个 对 象 ( 被 验证 的 对 象 ), 它 包含 
arguments. IsValid 和 arguments. Value 两 个 属性 ,前 者 指定 被 验证 对 象 是 否 有 效 , 后 者 引用 


被 验证 对 象 的 输入 值 。 下 面 给 出 一 个 使 用 CustomValidator 控件 进行 客户 端 验 证 的 示例 。 


【 例 7.5】 在 ch7 网 站 中 设计 一 个 WebForm5 网 页 ,其 功能 是 说 明 使 用 CustomValidator 


控件 进行 客户 端 验 证 的 方法 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch7 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,添加 
一 个 文件 名 称 为 WebForm5. aspx 的 代码 隐藏 模型 的 
网 页 。 

@ 本 网 页 的 设计 界面 如 图 7. 14 所 示 ,其 中 有 一 个 文 
本 框 TextBoxl ,一 个 命令 按钮 Buttonl ,一 个 标签 Labell 
和 一 个 CustomValidatorl 验证 控件 。 

CustomValidatorl 验证 控件 对 应 的 HTML 代码 
如 下 : 


[Label1] 直 有 通过 验证 


= » 
设计 |] 日 折 分 |。 源 | | <aspiTextBoxs|] 


图 7.14 WebForm5 网 页 设计 界面 


<asp:CustomValidator ID = "CustomValidatorl1l" runat = "server" 
Text = "没有 通过 验证 ”ClientValidationFunction = "valid" 
style= "color: 井 FF0OFF; font— size: medium; font— weight: 700; font - family: 仿宋 " 
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ControlToValidate = "TextBox1"> 
</asp:CustomValidator > 


@ 在 网 页 的 源 视 图 中 设计 如 下 客户 端 代码 : 


< script type = "text/javascript"> 
function valid(oSrc, args) { 
args.IsValid = (args.Value % 2 == 0); 


} 
</script> 
在 网 页 上 设计 如 下 事件 过 程 : 


protected void Page Load( object sender, EventArgs e) 
{ 
Labell. Text = ""; 

} 

protected void Button1_Cl ick(object sender, EventArgs e) 

{ 

Labell. Text = "通过 了 验证 "; 

} 

@ 单 击 工 具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 ,在 文本 框 中 输入 6, 单 击 “ 提 交 ” 命 令 
按钮 ,此 时 执行 客户 端 valid 函数 使 args. IsValid 二 True( 即 TextBoxl 输入 通过 验证 ), 回 传 给 
服务 器 ,执行 Button1_Click 事件 处 理 过 程 ,在 Labell 中 显示 “通过 了 验证 ”, 再 发 送 到 客户 端 ， 
客户 端 显 示 结 果 如 图 7. 15 所 示 。 

如 果 在 网 页 运行 时 在 文本 框 中 输入 5, 单 击 “ 提 交 ” 命 令 按 钮 ,此 时 执行 客户 端 valid 函数 
使 args. IsSValid 王 False( 即 TextBoxl 输入 没有 通过 验证 ) ,CustomValidatorl 验证 控件 显示 
信息 ,不 会 回 传 给 服务 器 ,客户 端 显示 结果 如 图 7. 16 所 示 。 


图 7.15 WebForm5 网 页 运行 界面 一 图 7.16 WebForm5 网 页 运行 界面 二 
7.2.6 ValidationSummary 控件 


ValidationSummary 控件 又 称 错误 总 结 控件 ,对 应 命名 空间 System. Web. UL WebControls 中 
的 ValidationSummary 类 。 该 控件 提供 一 个 集中 显示 验证 错误 信息 的 地 方 ,将 本 网 页 中 的 所 有 验 
证 控件 错误 信息 组 织 好 并 一 同 显示 出 来 。ValidationSummary 控件 的 常用 属性 如 表 7. 8 所 示 。 

根据 DisplayMode 属性 的 设置 ,摘要 可 以 按 列表 、 项 目 符号 列表 或 单个 段落 的 形式 显示 ， 
如 表 7. 9 所 示 。 通 过 分 别 设 置 ShowSummary 和 ShowMessageBox 属性 可 以 在 网 页 上 和 消息 
框 中 显示 摘要 。 

注意 : 如 果 ShowMessageBox 和 ShowSummary 属性 都 设置 为 True, 则 在 消息 框 和 网 页 
上 都 显示 验证 摘要 。 
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表 7.8 ValidationSummary 控件 的 常用 属性 


属 性 说 明 
HeaderText 控件 汇总 信息 
DisplayMode 获取 或 设置 验证 摘要 的 显示 模式 ,其 取 值 如 表 7. 9 所 示 


EnableClientScript ”获取 或 设置 一 个 值 ,用 于 指示 ValidationSummary 控件 是 否 使 用 客户 端 脚本 更 新 自身 

ShowMessageBox ”获取 或 设置 一 个 值 , 该 值 指示 是 否 在 消息 框 中 显示 验证 摘要 。 如 果 在 消息 框 中 显示 
验证 摘要 , 则 为 True, 否 则 为 False ,默认 为 False 

ShowSummary 获取 或 设置 一 个 值 ,该 值 指示 是 否 内 联 显示 验证 摘要 


表 7.9 DisplayMode 属性 取 值 及 其 说 明 


成 员 名 称 说 明 
BulletList 显示 在 项 目 符号 列表 中 的 验证 摘要 
List 显示 在 列表 中 的 验证 摘要 
SingleParagraph 显示 在 单个 段落 内 的 验证 摘要 


【 例 7.6】 在 ch7 网 站 中 设计 一 个 WebForm6 网 页 ,其 功能 是 说 明 ValidationSummary 
控件 的 使 用 方法 。 


解 : 其 步骤 如 下 。 _ 
O 打开 ch? 网 站 ,选择 网站 | 添加 新 和 


项 "命令 ,添加 一 个 文件 名 称 为 WebForm6. | 讲台 [ee 密 翅 不 能 
aspx 的 代码 隐藏 模型 的 网 页 。 | [ 两 次 密码 不 相同 
@ 本 网 页 的 设计 界面 如 图 7. 17 所 示 ， | 芋 生 和 生生 
错误 消息 2。 内 


其 中 有 3 个 文本 框 ( 从 上 到 下 分 别 为 
TextBoxl ~ TextBox3)、 一 个 命令 按钮 [swt |a 折 |。 亚 | [4][<body>|[<formsformi>| <dv> 站 
Buttonl 和 4 个 验证 控件 。 

4 个 验证 控件 对 应 的 HTML 代码 如 下 : 


<asp:RequiredFieldValidator ID = "RequiredFieldValidatorl1l" runat = "server" 
ControlToValidate = "TextBox1" CssClass = "auto- stylel3" 
ErrorMessage = "用 户 名 不 能 空 "> 

</asp:RequiredFieldValidator > 

<asp:RequiredFieldValidator ID = "RequiredFieldValidator2" runat = "server" 
ControlToValidate = "TextBox2" CssClass = "auto - stylel3" 
ErrorMessage = "密码 不 能 空 "> 

</asp:RequiredFieldValidator > 

<asp:CompareValidator ID = "CompareValidator1”runat = "server" 
ControlToCompare = "TextBox2”ControlToVal idate = "TextBox3" 
CssClass = "auto - style13" ErrorMessage = "两 次 密码 不 相同 "> 

</asp:CompareValidator > 

<asp:ValidationSummary ID = "ValidationSummaryl" runat = "server" DisplayMode = "List" 
Height = "38px" Width = "199px" style= "color: #FFOOFF; font - size: medium; 
font - weight: 700; font - family: 仿宋 " /> 


其 中 ValidationSummaryl 控件 的 DisplayMode 属性 设 为 List、ShowMessageBox 属性 设 
为 False( 默 认 值 )、ShowSummary 属性 设 为 True( 默 认 值 ) 。 

@ 单 击 工具 栏 中 的 Pp Internet Explorer 按钮 运行 本 网 页 ,在 "用 户 名 ”文本 框 中 输入 "licb”, 在 
“确认 密码 "文本 框 中 输入 “1234”, 单 击 “ 提 交 ” 命 令 按 钮 ,其 结果 如 图 7. 18 所 示 ,表示 没有 通过 


图 7.17 WebForm6 网 页 设计 界面 
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验证 ,并 在 ValidationSummaryl 控件 中 显示 所 有 错误 消息 。 
如 果 将 ValidationSummaryl 控件 的 ShowMessageBox 属性 改 为 Tue .ShowSummary 属性 改 
为 False, 同 样 操作 的 显示 结果 如 图 7. 19 所 示 , 只 是 改 为 在 一 个 消息 框 中 显示 所 有 错误 消息 。 


一 Cn 


Se 


图 7.18 WebForm6 网 页 运行 界面 一 7.19 ”WebForm6 网 页 运行 界面 二 


7.3 使 用 验证 组 


在 设计 网 页 时 ,有 时 将 许多 输入 显示 在 一 个 页 面 上 ,但 需要 对 输入 的 数据 进行 分 组 验证 ， 
这 就 需要 采用 验证 组 。 

ASP.NET 的 有 效 性 验证 控件 都 有 一 个 ValidationGroup 属性 , 它 用 于 设置 验证 组 名 称 ， 
验证 组 名 称 可 以 任意 指定 ,相同 ValidationGroup 属性 的 有 效 性 验证 控件 属于 同一 验证 组 。 
在 设置 ValidationGroup 属性 后 , 当 控件 触发 服务 器 回 发 时 , 仅 验证 指定 组 中 的 验证 控件 。 

说 明 : 当 有 效 性 验证 控件 没有 设置 ValidationGroup 属性 时 ,其 默认 值 为 空 ,这 样 网 页 中 
的 所 有 有 效 性 验证 控件 都 属于 这 个 默认 的 验证 组 。 

另外 , ASP . NET 提供 了 许多 能 够 回 发 到 服务 器 的 控件 , 如 Button、CheckBox、 
CheckBoxList 等 。 当 这 类 控件 的 CausesValidation 属性 设置 为 True( 默 认 值 ) 时 ,在 该 控件 回 
发 到 服务 器 时 执行 验证 。 

【 例 7.7】 在 ch7 网 站 中 设计 一 个 WebFormy7 网 页 ,其 功能 是 说 明 验 证 组 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 打开 ch7 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,添加 一 个 文件 名 称 为 WebForm7. aspx 的 
代码 隐藏 模型 的 网 页 。 

@ 本 网 页 的 设计 界面 如 图 7. 20 所 示 , 其 中 有 6 个 文本 框 ( 从 上 到 下 分 别 为 TextBoxl 一 
TextBox6) ,两 个 命令 按钮 (Buttonl 和 Button2) 和 6 个 验证 控件 ,这 些 验证 控件 分 为 groupl 
和 group2 两 个 验证 组 。 

按照 从 上 到 下 的 顺序 ,第 1 个 验证 控件 的 HTML 代码 如 下 : 


<asp:RequiredFieldValidator ID = "RequiredFieldValidator1”runat = "server" 
ErrorMessage= "用 户 名 不 能 空 " ControlToVal idate = "TextBox1" 
CssClass = "auto - style6" ValidationGroup = "groupl"> 
</asp:RequiredFieldValidator > 


第 2 个 验证 控件 的 HTML 代码 如 下 : 


<asp:RequiredFieldValidator ID = "RequiredFieldValidator2" runat = "server" 
ErrorMessage = "密码 不 能 空 "”ControlToValidate = "TextBox2" CssClass = "auto - style6" 
ValidationGroup ="groupl"> 


第 7 章 ， ASP.NET 验证 控 


</asp:RequiredFieldValidator > 


用 户 名 不 能 空 
密码 不 能 空 

两 次 密码 必须 相同 
年龄 在 16-50 之 间 


电话 格式 错误 
信箱 格式 错误 


4 
5 设计 |a 拆 分 |。 源 | [J[<body= <form#form1> |[<div> <ha> 上 时 


图 7.20 WebForm7 网 页 设计 界面 


第 3 个 验证 控件 的 HTML 代码 如 下 : 


<asp:CompareValidator ID = "CompareValidator1" runat = "server" 
ErrorMessage = "两 次 密码 必须 相同 ”ControlToCompare = "TextBox2" 


ControlToValidate = "TextBox3" CssClass = "auto ~ style6" ValidationGroup = "groupl"> 


</asp:CompareValidator > 


第 4 个 验证 控件 的 HTML 代码 如 下 : 


<asp:RangeVal idator ID = "RangeValidatorl"” runat = "server" 
ErrorMessage = "年 龄 在 16 - 50 之 间 " ControlToValidate = "TextBox4" 
CssClass = "auto— style6" MaximumValue = "50" MinimumValue = "16" 
Type = "Integer" ValidationGroup= "groupl"> 

</asp:RangeValidator > 


第 5 个 验证 控件 的 HTML 代码 如 下 : 


<asp:RegularExpressionValidator ID= "RegularExpressionValidatorl1" runat = "server" 


ErrorMessage = "电话 格式 错误 ”ControlToValidate = "TextBox5" 


CssClass = "auto- style6" ValidationExpression = "(\(\d{3}\)|\d{3}— )?\d{8}" 


ValidationGroup = " group2"> 
</asp:RegularExpressionValidator > 


第 6 个 验证 控件 的 HTML 代码 如 下 : 


<asp:RegularExpressionValidator ID = "RegularExpressionValidator2" runat = "server" 


ErrorMessage = "信箱 格式 错误 "ControlToValidate = "TextBox6" 
CssClass = "auto— style6" 


ValidationExpression="\w+ ([—+.']\wt+)x@\w+([—.]\wt+t)x\.\w+([-—.]\w+)*" 


ValidationGroup = "group2"> 
</asp:RegularExpressionValidator> 


“验证 1” 命 令 按钮 Buttonl 的 HTML 代码 如 下 : 


<asp:Button ID = "Button1”runat = "server" Text= "验证 1" CssClass = "auto- style5" 


ValidationGroup= "groupl" /> 
“验证 2” 命 令 按 钮 Button2 的 HTML 代码 如 下 : 


<asp:Button ID = "Button2” runat = "server"” Text= "验证 2" CssClass = "auto- style5" 


ValidationGroup = "group2" /> 
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从 上 看 到 ,网 页 中 共有 两 个 验证 组 , 即 groupl 和 group2, Buttonl 命令 按钮 用 于 验证 
groupl 验证 组 ,Button2 命令 按钮 用 于 验证 group2 验证 组 。 

@ 单 击 工具 栏 中 的 Internet Explorer 按钮 运行 本 网 页 ,在 用户 名 ”文本 框 中 输入 “licb”, 在 
“确认 密码 ”文本 框 中 输入 *1234”, 在 “年 龄 ”文本 框 中 输入 “65”, 单 击 “ 验 证 1” 命 令 按 钮 ,其 结 
果 如 图 7. 21 所 示 , 仅 仅 对 groupl 验证 组 进行 验证 。 

再 在 “电话 ”文本 框 中 输入 *1234”, 在 “信箱 ”文本 框 中 输入 “abcd. com”, 单 击 “ 验 证 2” 命 令 
按钮 ,其 结果 如 图 7. 22 所 示 , 仅 仅 对 group2 验证 组 进行 验证 。 


Pe ”eis 
(| hap/ocalhostss3s0WebFomsas PC es 


x 
py 


Pp” 
(加 OS mphocalhostss3s0WebFormsas P - oe 
证 昌 - 


两 次 密码 必须 相同 
年 龄 在 16-50 之 间 


| 

密码 [ ] | 密码 不 能 空 
] 
| 


电话 格式 错误 
信箱 格式 错误 


图 7.21 WebForm? 网 页 运行 界面 一 图 7.22 WebForm? 网 页 运行 界面 二 


采用 验证 组 可 以 设计 复杂 的 需要 多 组 输入 数据 验证 的 网 页 ,以 方便 分 阶段 进行 数据 验证 。 


练习 题 7 


1. 简 述 验证 控件 的 主要 作用 。 

2. 简 述 5 种 验证 控件 ( 即 RequiredFieldValidator、CompareValidator、 RangeValidator、 
RegularExpressionValidator 和 CustomValidator) 在 功能 上 的 差别 。 

3. 如 果 要 限定 网 页 中 某 个 文本 框 必须 输入 数据 ,应 该 使 用 什么 验证 控件 ? 

4， 如 果 要 限定 网 页 中 某 个 文本 框 输入 的 数字 在 0 一 100 之 间 ,应 该 使 用 什么 验证 控件 ? 

5. 如 果 要 限定 网 页 中 某 个 文本 框 输入 的 是 8 位 数字 的 电话 号 码 , 应 该 使 用 什么 验证 控件 ? 

6. 如 果 要 限定 网 页 中 某 个 文本 框 输入 的 是 特殊 的 但 无 法 用 正则 表达 式 表示 的 数据 格式 
(该 格式 可 以 用 某 个 程序 逻辑 表示 ) ,应 该 使 用 什么 验证 控件 ? 

7. CustomValidator 控件 是 一 个 服务 器 验证 控件 , 它 能 否 实现 客户 端 验证 ? 

8. 简 述 使 用 CustomValidator 控件 实现 客户 端 验 证 的 方法 。 

9. 使 用 验证 组 有 什么 作用 ? 

10. ASP.NET 的 有 效 性 验证 控件 的 ValidationGroup 属性 有 什么 用 途 ? 


上 机 实验 题 7 


在 ch7 网 站 中 添加 一 个 名 称 为 Experment7 的 网 页 ,用 于 输入 学 生 的 学 号 、 姓 名 ,性 别 和 
班 号 ,学 号 和 姓名 不 能 为 空 , 班 号 必须 以 "15? 开 头 。 例 如 ,没有 任何 输入 , 单 击 “确定 ”按钮 后 的 
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结果 如 图 7. 23 所 示 ; 班 号 输入 不 以 *15" 开 头 , 单 击 * 确 定 "按钮 后 的 结果 如 图 7. 24 所 示 ; 数据 
输入 正确 , 单 击 “ 确 定 "按钮 后 的 结果 如 图 7. 25 所 示 。 
re FE 
re < 司 


学 号 不 能 为 空 
姓名 不 能 为 空 


图 7.23 上 机 实验 题 7 的 网 页 运行 界面 一 图 7.24 上 机 实验 题 7 的 网 页 运行 界面 二 


学 号 


性 别 


班 号 


输入 信息 : 
St :301 姓名 : 陈 功 
别 : 男 ” 班 号 :15001 


7.25 上 机 实验 题 7 的 网 页 运行 界面 三 
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ASP. NET 提供 了 用 户 控件 设计 功能 。 用 户 控 件 基本 的 应 用 就 是 把 网 页 中 
经 常用 到 的 程序 封装 到 一 个 单元 中 ,以 便 在 其 他 网 页 中 使 用 ,从 而 提高 应 用 程 
序 的 开发 效率 。 本 章 介绍 用 户 控 件 的 创建 和 使 用 方法 。 

本 章 学 习 要 点 : 

回 掌 握 用 户 控件 的 基本 概念 。 

回 掌 握 用 户 控件 的 创建 过 程 以 及 设置 属性 和 方法 的 过 程 。 

回 掌 握 用 户 控件 的 使 用 方法 。 


8.1 用 户 控件 概述 


用 户 控件 由 一 个 或 多 个 ASP. NET 服务 器 控件 (如 Button 控件 .TextBox 
控件 等 ) 以 及 相关 的 功能 代码 组 成 。 用 户 控 件 还 可 以 包括 自 定义 属性 或 方法 ， 
这 些 属性 或 方法 向 ASP. NET 网 页 显示 用 户 控 件 的 功能 。 

用 户 控 件 几乎 与 网 页 .aspx 文件 相似 ,但 仍 有 以 下 不 同 之 处 : 

。 用 户 控件 的 文件 扩展 名 为 . ascx。 

。 用 户 控件 中 没有 @Page 指令 ,而 是 包含 @Control 指令 ,该 指令 对 配置 
及 其 相关 属性 进行 定义 。 

用 户 控件 不 能 作为 独立 文件 运行 ,而 必须 像 其 他 控件 一 样 将 其 添加 到 

ASP.NET 网 页 中 。 

。 用 户 控件 中 没有 html、body 或 form 元 素 。 

用 户 控 件 的 主要 优点 如 下 : 

。 可 以 将 常用 的 内 容 或 控件 以 及 控件 的 运行 程序 逻辑 设计 为 用 户 控件 , 然 
后 便 可 以 在 多 个 网 页 中 重复 使 用 该 用 户 控件 ,从 而 省 略 许多 重复 性 的 
工作 。 

。 网 页 内 容 需要 改变 时 只 需 修 改 用 户 控件 中 的 内 容 , 其 他 应 用 用 户 控件 的 

网 页 会 自动 随 之 改变 ,因此 网 页 的 设计 和 维护 更 加 方便 。 


8.2 创建 用 户 控件 
8.2.1 创建 用 户 控件 的 过 程 
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创建 用 户 控件 的 过 程 与 创建 网 页 文件 十 分 相似 ,下 面 通过 一 个 示例 说 明 。 
【 例 8.1】 在 D 盘 ASP.NET 目录 中 建立 一 个 ch8 的 子 目录 ,将 其 作为 网 站 目录 ,然后 创 


建 一 个 WebForml 网 页 ,其 功能 是 说 明 用 户 控件 的 创建 过 程 。 
解 : 其 步骤 如 下 。 
@ 启动 Visual Studio 2012。 


@ 选择 "文件 | 新 建 | 网 站 ”命令 ,出 现 * 新 建 网 站 ?对 话 框 ,选择 “ASP.NET 空 网 站 ”模板 ， 
选择 "Web 位置" 为 “文件 系统 ”, 单 击 “ 浏 览 ” 按 钮 ,选择 “D:\ASP.NET\ch8" 目 录 , 单 击 “ 确 定 ” 


按钮 ,创建 一 个 空 的 网 站 ch8。 


@ 选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch8” 对 话 框 ,在 中 间 列 表 中 选择 “Web 用 


户 控件 ”模板 ,保持 默认 名 称 为 WebUserControl. ascx, 如 图 8. 1 所 示 , 单 击 “ 添 加 ”按钮 。 


图 8. 1 “添加 新 项 -ch8” 对 话 框 


x 


@ 进入 用 户 控 件 的 设计 视图 ,插入 一 个 2X2 的 表格 , 输 [webuserconro - 


入 两 个 HTML 标签 ,然后 拖 放 两 个 文本 框 (TextBoxl 和 = 
了 手 弛 : 】 
TextBox2) ,如 图 8.2 所 示 。 | 
@ 进入 源 视 图 ,看 到 其 源 视图 代码 如 下 : ~ 
-一 一 一 一 一 一 一 
<$% @Control Language = "C 井 ”RutoEventWireup = "true" 和 设计 |] @ 折 分 | = 潭 | 
CodeFile = "WebUserControl. ascx.cs”Inherits = 
和 全 图 8.2 WebUserControl. ascx 
< style type = "text/css"> 
设计 界面 


.auto— stylel { 
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width: 200px; 
} 
.auto— style2 { 
font -family: 楷体 ; font- size: medium; 
color: 井 0000FF; font - weight: bold; 
} 
.auto— style3 { 
font - family: Arial; font ~ weight: bold; 
font ~ size: small; 
四 
</style> 
<table class = "auto - stylel"> 
<tr > 
<td class = "auto- style2"> 学 号 : </td> 
<td> 
<asp:TextBox ID = "TextBox1" runat = "server" 
CssClass = "auto - style3" Width= "87px"></asp: TextBox> 
</td> 
</tr> 
<tr> 
<td class = "auto- style2"> 姓 名 : </td> 
<td> 
<asp:TextBox ID = "TextBox2" runat = "server" 
CssClass = "auto - style3" Width= "85px"></asp: TextBox > 
</td> 
</tr> 
</table> 


此 新 控件 的 标记 与 ASP .NET 网 页 的 标记 相似 ,只 是 它 包 含 @Control 指令 ,而 不 含 
@Page 指令 ,并 且 用 户 控 件 没有 html、body 和 form 元 素 。 

注意 : 不 能 将 用 户 控 件 放 在 网 站 的 App_Code 目录 中 ,和 否则 运行 包含 该 控件 的 网 页 时 会 
出 错 。 


8.2.2 设置 用 户 控件 


用 户 控件 中 可 能 包含 服务 器 控件 ,包含 该 控件 的 网 页 无 法 直接 访问 它们 ,但 可 以 通过 设计 
用 户 控件 的 相关 属性 和 方法 间接 访问 它们 。 

1. 设置 用 户 控件 的 属性 

实际 上 ,用 户 控件 就 是 一 个 类 ,其 中 包含 的 其 他 控件 等 都 是 私有 的 ,外 部 无 法 访问 它们 。 
为 了 能 通过 该 类 的 对 象 访问 这 些 私 有 成 员 ,可 以 通过 设计 属性 的 方式 来 实现 。 

例如 ,对 于 前 面 设计 的 WebUserControl. ascx 用 户 控 件 ,无 法 通过 其 对 象 访问 文本 框 ,为 
此 在 WebUserControl 用 户 控件 的 设计 视图 中 右 击 ,在 出 现 的 快捷 菜单 中 选择 “查看 代码 ” 命 
令 进入 代码 编辑 窗口 ,在 WebUserControl 类 声明 中 增加 如 下 后 台 代码 : 

public string sno // 公 共 属 性 

和 get { return TextBox1l. Text; } 

set { TextBoxl.Text = value; } 
J string sname // 公 共 属 性 
{ get { return TextBox2. Text; } 


set { TextBox2.Text = value; } 
} 
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上 述 代码 定义 了 用 户 控 件 的 两 个 属性 , 均 为 get 和 set 属性 。sno 属性 对 应 TextBox1l 文 
本 框 的 读 / 写 ,sname 属性 对 应 TextBox2 文本 框 的 读 / 写 ,这 样 就 可 以 通过 sno 和 sname 属性 
访问 其 中 的 两 个 文本 框 了 。 

2. 设置 用 户 控件 的 方法 

和 设置 用 户 控件 的 属性 一 样 , 可 以 通过 设置 用 户 控件 的 公共 方法 来 达到 访问 用 户 控 件 中 
成 员 的 目的 ,下 面 通过 一 个 示例 说 明 。 

【 例 8.2】 创建 一 个 用 户 控 件 WebUserControll. ascx， 
其 中 包含 一 个 列表 框 ListBoxl ,并 设计 相关 公共 方法 实现 对 
列表 框 的 操作 。 

解 : 其 步骤 如 下 。 

@ 打开 ch8 网 站 ,采用 例 8. 1 的 方式 创建 用 户 控件 
WebUserControll. ascx。 

@ 其 设计 界面 如 图 8. 3 所 示 , 包 含 一 个 HTML 标签 和 [BF eS “如 | [<powe| 
一 个 列表 框 ListBoxl, 将 其 SelectionMode 属性 设置 为 
Multiple。 

@) 在 该 用 户 控件 上 设计 如 下 方法 : 


public ;int count() // 返 回 列表 框 中 的 选项 个 数 
return ListBox1. Items. Count; 

a void clear() // 删 除 所 有 选项 

ListBoxl. Ttems. Clear(); 

i void add( string item) // 添 加 一 个 字符 串 

, ListBox1. Items. Rdd( item) ; 

a void add(ListItem item) // 重 载 函 数 , 添 加 一 个 ListItenm 选项 
| ListBoxl. Items. Add( item); 

i void remove(int i) // 删 除 指定 索引 的 选项 
ListBox1. Ttems. RemoveAt (i); 

int selectedindex() // 返 回 当前 选择 选项 的 索引 
! return ListBox1. SelectedIndex; 

Li ListItem indexitem( int i) // 返 回 指定 索引 的 选项 

{ 


图 8.3 WebUserControll. ascx 
用 户 界面 


return ListBoxl. Items[i]; 
} 


上 述 方法 都 是 通过 ListBox 控件 的 相关 属性 和 方法 来 实现 的 ,只 不 过 不 能 通过 
WebUserControll 用 户 控件 的 对 象 直接 调用 ListBoxl 控件 的 这 些 属性 和 方法 罢了 ,而 是 改 为 
调用 上 述 方法 实现 相同 的 功能 。 
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8.3 使 用 用 户 控件 


将 ASP.NET 用 户 控件 添加 到 网 页 类 似 于 将 其 他 服务 器 控件 添加 到 网 页 ,但 是 请 务必 遵 
循 下 列 过 程 ,以 便 将 所 有 必需 的 元 素 添 加 到 网 页 中 。 向 网 页 添加 ASP.NET 用 户 控件 的 过 程 
如 下 : 

@ 打开 要 添加 ASP.NET 用 户 控件 的 网 页 。 

@ 切换 到 设计 视图 。 

Q 在 “解决 方案 资源 管理 器 ?中 选择 自 定 义 用 户 控件 文件 ,并 将 其 拖 到 网 页 上 。 

当 ASP.NET 用 户 控件 被 添加 到 该 网 页 面 时 ,设计 器 会 创建 @Register 指令 ,网 页 需要 它 
来 识别 用 户 控 件 。 现 在 就 可 以 处 理 该 控件 的 公共 属性 和 方法 了 。 

【 例 8.3】 在 ch8 网 站 中 设计 一 个 WebForml 网 页 ,其 功能 是 说 明 前 面 创建 的 
WebUserControl. ascx 用 户 控件 的 使 用 方法 。 


解 : 其 步骤 如 下 。 
@ 打开 ch8 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,添加 一 个 文件 名 称 为 WebForm2. aspx 的 
代码 隐藏 页 模型 的 网 页 。 


@ 切换 到 网 页 的 设计 视图 ,在 “解决 方案 资源 管理 器 ”中 选择 WebUserControl. ascx 文件 
将 其 拖 到 网 页 上 ,这 样 将 在 网 页 中 生成 一 个 名 称 为 WebUserControll 的 用 户 控 件 。 另 外 添加 
两 个 Button 控件 ("确定 ”命令 按钮 Buttonl 和 “ 重 置 " 命 令 按钮 Button2) 和 一 个 Label 控件 
Labell( 其 Text 属性 设 为 空 ) ,本 网 页 的 设计 界面 如 图 8.4 所 示 。 在 该 网 页 上 设计 如 下 事件 
过 程 : 
protected void Button1_Cl ick(object sender, EventArgs e) 
{ ”Labell.Text = "输入 数据 如 下 :”+ "<br>"; 
Labell. Text += "学 号 :" + WebUserControll. sno; 
Labell. Text += " 姓名 :" + WebUserControll. sname; 
} 
protected void Button2_Click(object sender, EventArgs e) 
{ WebUserControll.sno = ""; 
WebUserControl1. sname = ""; 
j 


@ 本 网 页 的 源 视图 代码 如 下 : 


<% @Page Language = "C 井 ”RutoEventWireup = "True" 
CodeFile = "WebForml.aspx.cs" Inherits = "WebForml" %> 
<% @Register src = "WebUserControl.ascx" tagname = "WebUserControl" tagprefix= "ucl" %> 
<!DOCTYPE html > 
<html xmlns = "http://www. w3.org/1999/xhtml"> 
<head runat = " server"> 
<meta http ~ equiv= "Content ~ Type" content = "text/htm1; charset = utf— 8"/> 
<title></title> 
< style type= "text/css"> 
.auto— style4 { 
font - family: 黑体 ; font - weight: bold; 
font - size: medium; color: 提 FF0000; 
</style> 
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</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
<ucl:WebUserControl ID = "WebUserControll1" runat = "server" /> 
</div> 
<br /> 
<asp:Button ID = "Buttonl" runat = "server" CssClass= "auto— style4" 
OnClick = "Buttonl_Click" Text = "确定 " /> 
&nbsp; gnbsp; gnbsp; 
<asp:Button ID = "Button2" runat = "server" CssClass= "auto 一 style4" 
OnClick = "Button2_Click" Text = " 重 置 " /> 
<br /><br /> 
<asp:Label ID = "Labell" runat = "server" style= "color: #3FFOOFF;font - size: medium; 
font - weight: 700; font - family: 仿宋 "></asp:Label> 
</form> 
</body> 
</html > 


其 中 自动 添加 的 @Register 指令 用 来 标识 用 户 控件 WebUserControl。 
@ 单 击 工 具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,在 两 个 文本 框 中 分 别 输入 “106” 和 
王 华 ”, 单 击 “ 确 定 ” 命 令 按 钮 ,其 结果 如 图 8.5 所 示 。 
[CI - 


区 


学 号 : | 


名 : [ | 
| 殉 定 | 。 | 重 二 | 


[Label1] 


hem ol- 
5 设计 ]a 折 分 |。 源 | [4|<dv> 加 


图 8.4 WebForml 网 页 设计 界面 图 8.5 WebForml 网 页 运行 界面 


上 例 说 明了 用 户 控 件 中 属性 的 使 用 ,实际 上 代码 WebUserControll. sno 就 是 使 用 ID 为 
WebUserControll 的 用 户 控件 的 sno 属性 。 由 于 该 属性 为 get 和 set 属性 ,所 以 可 以 进行 
读 / 写 操作 。 

下 面 介绍 一 个 使 用 用 户 控 件 的 较 复杂 的 示例 。 

【 例 8. 4】〗 在 chg 网 站 中 设计 一 个 WebForm2 网 页 ,其 功能 是 说 明 前 面 创建 的 
WebUserControll. ascx 用 户 控件 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch8 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,添加 一 个 文件 名 称 为 WebForm2. aspx 的 
代码 隐藏 页 模型 的 网 页 。 

@ 切换 到 网 页 设计 视图 ,采用 二 div 二 元 素 设 计 4 个 区 块 ,在 第 1 个 区 块 中 放 入 一 个 
WebUserControll 用 户 控 件 WebUserControll1, 在 第 2 个 区 块 中 放 入 4 个 Button 控件 (从 上 
到 下 分 别 为 Buttonl ~ Button4) .在 第 3 个 区 块 中 放 入 一 个 WebUserControll 用 户 控 件 
WebUserControl12 ,在 第 4 个 区 块 中 放 人 一 个 标签 控件 Labell ,其 设计 界面 如 图 8. 6 所 示 。 
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其 中 4 个 命令 按钮 的 功能 如 下 。 
。 过 >: 将 左 列表 框 中 的 所 有 项 目 移动 到 右 列表 框 中 。 
。 二 : 将 左 列表 框 中 选 定 的 项 目 移动 到 右 列表 框 中 。 
"去 去: 将 右 列表 框 中 的 所 有 项 目 移动 到 左 列表 框 中 。 
。 去 : 将 右 列 表 框 中 选 定 的 项 目 移动 到 左 列表 框 中 。 


在 该 网 页 上 设计 如 下 事件 过 程 : 
protected void Page_Load( object sender, EventArgs e) 
{ if (!Page.IsPostBack) // 如 果 网 页 为 首次 加 载 , 则 执行 以 下 语句 


{ ”WebUserControl11.add(" 清 华 大 学 "); 
WebUserControl11.add(" 北 京 大 学 "); 
WebUserControl11.add(" 中 国 科技 大 学 "); 
WebUserControl11.add(" 南 京 大 学 "); 
WebUserControl11.add(" 华 中 科技 大 学 "); 
WebUserControl11.add(" 上海 交 通 大 学 "); 
WebUserControl11.add(" 武 汉 大 学 "); 

Labell. Text = ""; 
} 
} 
protected void Buttonl_Click(object sender, EventArgs e) 
int i; 

ListItem item; 

for (i = 0; i< WebUserControl11. count(); i++) 

{ item = WebUserControlll. indexitem(i); 
WebUserControl12.add( item); 

} 

WebUserControlll1. clear(); 

Label1. Text = "操作 成 功 "; 

} 
protected void Button2_Click(object sender, EventArgs e) 
{ int i; 

ListItem item; 

i = WebUserControl11. selectedindex(); 

if (i>= 0 && i< WebUserControlll1.count()) 

{ item = WebUserControlll. indexitem(i); 
WebUserControl12.add( item); 
WebUserControll11. remove( i); 

Labell. Text = "操作 成功"; 

} 

else 
Labell.Text = "没有 选择 任何 选项 "; 

} 
protected void Button3_Click(object sender, EventArgs e) 
{ int i; 

ListItem item; 

for (i = 0; i< WebUserControl12. count(); i++) 

{ 让 em = WebUserControl12. indexitem(i); 
WebUserControl11.add( item); 

} 

WebUserControl12. clear( ); 

Labell. Text = "操作 成 功 "; 

} 
protected void Button4_Click(object sender, EventArgs e) 
{ int i; 
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ListItem item; 

i = WebUserControll12. selectedindex( ); 

if (i>= 0 && i < WebUserControl12.count()) 

{ item = WebUserControl12. indexitem(i); 
WebUserControl11.add( item); 
WebUserControl12. remove( i); 
Labell. Text = "操作 成 功 "; 

} 

else 
Labell.Text = "没有 选择 任何 选项 "; 

} 


@ 单 击 工 具 栏 中 的 p> Inmternet Explorer 按钮 运行 本 网 页 ,首先 在 左 列表 框 中 显示 几 所 大 学 的 
名 称 ,选中 “北京 大 学 ”, 单 击 “ 二 ”命令 按钮 将 其 移 到 右 列 表 框 中 ,再 选中 “武汉 大 学 ”, 单 击 “ 二 ” 
命令 按钮 将 其 移 到 右 列表 框 中 ,其 结果 如 图 8. 7 所 示 。 


orm2.aspx 1 = 于 = ET 
RE EEC 
[Socbon “上 GEE 
和 
大 手表 
图 请 究 天 学 
7 中 国 科技 大 学 
南京 大 学 
| 他 中 科技 大 学 
上 海 交通 大 学 
[LLabel1] 
二 2 操作 上 成功 
1 52 » 
设计 | 日 拆 分 |。 源 | [4] <aspiButtonauto-style3# |» 


图 8.6 WebForm2 网 页 设计 界面 图 8.7 WebForm2 网 页 运行 界面 


8.4 将 网 页 转化 为 用 户 控件 


在 应 用 程序 的 开发 过 程 中 ,有 些 网 页 会 经 常用 到 且 使 用 频率 较 高 ,可 以 将 其 略 加 改动 变 为 
一 个 用 户 控件 。 将 网 页 转换 为 用 户 控件 分 为 两 种 情况 ,下 面 分 别 介绍 。 
8.4.1 将 单个 网 页 转换 成 用 户 控件 

将 单个 网 页 转换 成 用 户 控件 的 步骤 如 下 : 

@ 重 命名 控件 ,将 文件 扩展 名 改 为 . ascx。 

@ 从 网 页 中 删除 html、body 和 form 元 素 。 

@ 将 @Page 指令 更 改 为 @Control 指令 。 


@ 删除 @ Control 指令 中 除 Language、AutoEventWireup (如 果 存 在 )、CodeFile 和 
Inherits 以 外 的 所 有 属性 。 


@ 在 @Control 指令 中 包含 ClassName 属性 (该 属性 用 于 将 用 户 控 件 添加 到 网 页 时 进行 
强 类 型 化 ) 。 


8.4.2 将 代码 隐藏 网 页 转换 成 用 户 控件 
将 代码 隐藏 网 页 转换 成 用 户 控件 的 步 又 如 下 ; 
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第 1 步 : 重 命名 .aspx 文件 ,使 其 文件 扩展 名 为 . ascx。 

第 2 步 : 将 代码 隐藏 文件 的 扩展 名 更 改 为 . ascx. cs。 

第 3 步 : 打开 代码 隐藏 文件 并 将 该 文件 继承 的 类 从 Page 类 更 改 为 UseControl 类 ,即将 
System. Web. UI. Page 语句 更 改 为 System. Web. UI UserControl。 

第 4 步 : 在 .aspx 文件 中 执行 以 下 操作 。 

@ 从 网 页 中 删除 html、body 和 form 元 素 。 

@ 将 @Page 指令 更 改 为 @Control 指令 。 

@@ 删除 @ Control 指令 中 除 Language、AutoEventWireup (如 果 存 在 )、CodeFile 和 
Inherits 以 外 的 所 有 属性 。 

@ 在 @Control 指令 中 将 CodeFile 属性 更 改 为 指向 重 命 名 的 代码 隐藏 文件 。 

@ 在 @Control 指令 中 包含 ClassName 属性 (该 属性 用 于 将 用 户 控件 添加 到 网 页 时 进行 
强 类 型 化 ) 。 

对 于 采用 上 述 将 网 页 转化 为 用 户 控件 的 方式 建立 的 用 户 控 件 , 其 使 用 方式 与 直接 创建 的 
用 户 控 件 的 完全 相同 。 


练习 题 8 


. 简 述 用 户 控 件 的 作用 。 

. 简 述 用 户 控件 的 设计 过 程 。 

. 简 述 用 户 控件 的 使 用 方法 。 

. 在 一 个 用 户 控件 设计 中 是 否 可 以 使 用 另外 的 用 户 控件 ? 
. 简 述 将 网 页 转化 为 用 户 控件 的 方法 。 


上 机 实验 题 8 
在 ch8 网 站 中 添加 一 个 用 户 控件 WebUserControl2. ascx, 其 功能 是 用 于 登录 信息 (用 户 


名 和 密码 ) 的 输入 。 另 外 创建 一 个 名 称 为 Experment8 的 网 页 ,使 用 该 用 户 控件 实现 用 户 登 
录 , 在 单 击 “ 确 定 ” 命 令 按钮 后 在 一 个 标签 中 显示 用 户 登录 信息 ,如 图 8. 8 所 示 。 


wD 


OB worn o- 
| 


优 localhost 


用 户 名 [101 用 户 控件 


输入 信息 如 下 : 
用 户 名 : 101 
窗 三 :123456 


图 8.8 上 机 实验 题 8 网 页 的 运行 界面 
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主题 和 母 版 页 有 一 个 共同 的 特点 ,就 是 统一 网 页 设计 风格 和 样式 ,达到 代 
码 共享 的 目的 ,从 而 提高 网 站 开发 的 效率 ,但 两 者 的 侧重 点 是 不 同 的 ,本 章 介绍 
它们 的 使 用 方法 。 

本 章 学 习 要 点 : 

回 掌 握 主题 和 外 观 文件 的 概念 和 特点 。 

回 掌 握 创 建 外 观 文件 的 过 程 以 及 应 用 主题 和 禁用 主题 的 方法 。 

回 掌 握 母 版 页 和 内 容 页 的 概念 与 特点 。 

回 掌握 母 版 页 和 内 容 页 的 设计 方法 。 

回 掌握 内 容 页 中 访问 母 版 页 内 容 的 方法 。 


9.1 主题 


9.1.1 主题 概述 


主题 CTheme) 是 指 网 页 和 控件 外 观 属性 设置 的 集合 ,其 工作 原理 类 似 于 
CSS ,为 网 站 提供 统一 的 风格 。 在 CSS 中 ,可 以 将 定义 的 a:link 样式 (指定 未 被 
访问 过 的 超 链 接 的 样式 ) 存 放 在 一 个 外 部 样式 表 文 件 中 ,然后 在 网 站 各 网 页 中 
包含 对 这 个 文件 的 引用 . 则 结果 网 站 中 所 有 的 超 链 接 样式 便 统一 成 这 个 文件 中 
定义 的 那样 了 。 

主题 提供 了 一 种 简易 方式 ,可 以 独立 于 应 用 程序 的 网 页 为 网 站 的 控件 和 网 
页 设置 样式 ,因此 便于 Web 应 用 程序 对 其 进行 维护 。 一 个 网 站 可 以 有 多 个 主 
题 ,这 样 在 设计 网 站 时 可 以 先 不 考虑 样式 ,在 以 后 要 进行 样式 设计 时 也 无 须 更 
新 网 页 或 更 改 代码 。 另 外 .还 可 以 从 外 部 获得 自 定义 主题 ,例如 将 另 一 个 网 站 
的 主题 复制 到 本 网 站 中 ,因此 主题 可 以 方便 地 重用 。 

实际 上 ,主题 是 存在 于 App_Themes 目录 中 的 一 个 子 目 录 , 每 个 子 目录 就 
是 一 个 主题 ,其 中 包含 外 观 文件 (. skin) .CSS 文件 (. css, 样 式 表 文件 )、 图 像 文 
件 和 其 他 资源 。 

在 设计 网 页 时 不 必 在 网 页 中 显 式 引用 主题 ,只 需 把 它们 放 到 App_Thems 
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目录 中 ,应 用 程序 会 自动 加 载 相 关 的 主题 。 

注意 : 在 一 个 主题 下 必须 至 少 包 含 一 个 外 观 文件 ,也 可 以 有 多 个 外 观 文件 。 

1. CSS 文件 

CSS 文件 在 主题 出 现 之 前 已 经 得 到 广泛 的 应 用 (在 第 3 章 已 介绍 ) ,将 CSS 文件 放 到 主题 
目录 中 便 作为 主题 的 一 部 分 。 主 题 中 的 CSS 文件 和 非 主题 中 的 CSS 文件 没有 本 质 的 区 别 , 只 
是 主题 CSS 文件 自动 作为 主题 的 一 部 分 ,在 网 页 中 只 引用 主题 即 可 ,不 必 再 单独 引用 CSS 
文件 。 

2. 外 观 文件 

外 观 文件 也 称 为 皮肤 文件 , 它 是 主题 的 核心 内 容 , 用 于 定义 网 页 中 各 种 服务 器 控件 (如 
Button、TextBox 或 Label 控件 等 ) 的 外 观 属性 。 外 观 文件 由 一 组 控件 的 特定 主题 的 外 观 标记 
组 成 ,其 扩展 名 为 . skin。 例 如 ,以 下 代码 设置 Button 控件 的 外 观 : 


<asp:Button runat = "server" BackColor = "black" ForeColor = "Red" /> 


同一 类 型 控件 的 外 观 标 记分 为 默认 外 观 标记 和 命名 外 观 标记 两 种 。 

(1) 默认 外 观 标记 

默认 外 观 标记 不 设置 控件 的 SkinID 属性 , 它 自动 应 用 于 同一 类 型 的 所 有 控件 。 在 同一 主 
题 中 只 能 有 同一 类 型 控件 的 一 个 默认 外 观 标记 ,哪怕 同一 主题 下 有 多 个 外 观 文件 ,但 同一 类 型 
控件 的 默认 外 观 标记 也 只 能 有 一 个 。 上 述 一 asp:Button … /二 就 是 默认 外 观 标记 的 形式 ,该 
控件 外 观 标记 适用 于 使 用 本 主题 的 网 页 上 的 所 有 Button 控件 。 

默认 外 观 标记 严格 按 控件 类 型 来 匹配 ,因此 Button 控件 外 观 标 记 适 用 于 所 有 Button 控 
件 , 但 不 适用 于 LinkButton 控件 或 从 Button 对 象 派生 的 控件 。 

(2) 命名 外 观 标记 

设置 有 控件 的 SkinID 属性 的 外 观 标记 称 为 命名 外 观 标记 。 命 名 外 观 标 记 不 会 自动 按 类 
型 应 用 于 控件 ,而 应 当 通 过 设置 控件 的 SkinID 属性 将 已 命名 外 观 标 记 显 式 应 用 于 控件 。 通 过 
创建 已 命名 外 观 标记 可 以 为 应 用 程序 中 同一 控件 的 不 同 实 例 设 置 不 同 的 外 观 。 例 如 ,前面 的 
代码 指定 命令 按钮 的 默认 外 观 标记 ,应 用 于 网 页 中 的 所 有 命令 按钮 ,而 以 下 代码 属 命名 外 观 
标记 ， 

<asp:Button SkinID = "buttonskin1" BackColor = "gray"” /> 

<asp:Button SkinID = "buttonskin2" BackColor = "white" /> 

这 样 为 命令 按钮 设置 了 两 种 外 观 , 在 应 用 时 需 指 定 命令 按钮 控件 的 SkinID 属性 是 
buttonskinl 或 buttonskin2 ,这 就 是 为 什么 几乎 所 有 控件 都 有 SkinID 属性 的 原因 。 

3. 外 观 文 件 中 的 外 观 标记 与 控件 标记 的 区 别 

外 观 文件 中 的 外 观 标记 与 控件 标记 类 似 , 不 过 有 几 个 区 别 。 第 一 个 区 别 是 外 观 文件 中 的 
外 观 标记 不 能 有 ID 属性 。ID 用 来 唯一 标识 网 页 中 的 控件 ,由 于 外 观 文件 是 应 用 到 所 有 控件 
的 ,因此 没有 必要 给 它 一 个 ID 属性 。 

另 一 个 区 别 在 于 能 在 标记 中 设置 属性 的 个 数 ,并 不 是 控件 的 所 有 属性 都 能 应 用 外 观 , 例 
如 ,不 能 通过 外 观 文件 设置 Button 按钮 的 Enabled 属性 。 一 般 来 说 ,影响 外 观 的 属性 如 
BackColor、ForeColor、BorderColor 等 可 以 应 用 外 观 , 而 影响 行为 的 属性 如 Enabled、 
EnableViewState 和 TextBox 的 TextMode 等 不 能 应 用 外 观 。 
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4. 外 观 和 样式 表 的 区 别 和 联系 
外 观 和 样式 表 的 主要 区 别 和 联系 如 下 : 
。 可 以 通过 外 观 文件 使 网 页 中 的 多 个 服务 器 控件 具有 相同 的 外 观 , 如 果 用 样式 表 来 实 

现 , 则 必须 设置 每 个 控件 的 CssClass 属性 才能 将 样式 表 中 定义 的 样式 类 应 用 于 这 些 

控件 ,非常 烦琐 。 
。 使 用 样式 表 虽 然 能 够 控制 网 页 中 各 种 元 素 的 样式 ,但 是 有 些 服务 器 控件 的 属性 却 无 法 
用 样式 表 控 制 ,而 外 观 文件 可 以 轻松 完成 这 些 功 能 。 
当 控 制 属性 比较 多 的 服务 器 控件 外 观 时 ,可 能 需要 在 CSS 文件 中 定义 很 多 
果 这 些 CSS 类 之 间 定 义 不 好 有 可 能 产生 不 希望 的 效果 ,而 用 外 观 文件 不 会 出 现 
问题 。 

。 每 个 网 页 只 能 应 用 一 个 主题 ,不 能 向 一 个 网 页 应 用 多 个 主题 ,这 与 样式 表 不 同 ,样式 表 

可 以 向 一 fe en 

5. 主题 图 形 和 其 他 资源 

主题 还 可 以 包含 图 形 和 其 他 资源 ,例如 脚本 文件 或 声音 文件 。 通 常 主题 的 资源 文件 与 该 
主题 的 外 观 文件 位 于 同一 个 目录 中 ,但 它们 也 可 以 位 于 Web 应 用 程序 中 的 其 他 地 方 ,如 位 于 
主题 目录 的 某 个 子 目 录 中 。 例 如 , 若 要 引用 主题 目录 的 某 个 子 目录 中 的 资源 文件 ,可 以 使 用 类 
似 于 如 下 Image 控件 外 观 中 显示 的 路 径 : 

<asp:Image runat = "server"” ImageUrl = "主题 子 目录 /图 像 文 件 名 ”人 > 


9.1.2 创建 主题 


1. 创建 主题 的 过 程 

主题 必须 存放 于 网 站 根 目录 下 的 App_Themes 目录 中 , 且 每 个 主题 本 身 就 是 一 个 目录 。 
这 里 以 创建 网 站 ch9 的 主题 为 例 ,其 步骤 如 下 : 

@ 在 D 盘 ASP.NET 目录 中 建立 一 个 ch9 的 子 目录 ,以 “ASP.NET 空 网 站 ”为 模板 创建 
一 个 名 称 为 ch9 的 空 网 站 。 

@ 在 “解决 方案 资源 管理 器 "中 右 击 项 目 名称 ch9, 在 出 二 
现 的 快捷 菜单 中 选择 * 添 加 | 添加 ASP.NET 文件 夹 | 主题 ” iaaglecaaalalB 
命令 ,系统 会 自动 创建 一 个 位 于 根 目 录 下 的 App_Themes 。 者 解 上 方案 资 源 管理 中 (curl A 
目录 ,并 在 该 目录 中 创建 一 个 待命 名 的 主题 (默认 名 称 为 " 主 。“ 吉 各 9 0 全 
题 1”) ,如 图 9. 1 所 示 。 将 “主题 1" 改 为 Blue( 主 题名 起 到 区 i 医生 i 


分 不 同 主题 的 目的 )。 pe 
@ 石 击 主题 Blue, 在 出 现 的 快捷 菜单 中 选择 “添加 | 添 
加 新 项 "命令 ,打开 “添加 新 项 -ch9” 对 话 框 ,选择 “外 观 文件 ” 图 9.1 添加 主题 


模板 ,如 图 9.2 所 示 。 

@ 单 击 “ 添 加 ”按钮 ,将 会 为 Blue 主题 添加 一 个 外 观 文件 ,这 里 采用 默认 的 外 观 文件 名 
SkinFile. skin ,接着 进入 编辑 窗口 开始 编辑 外 观 文件 。 例 如 ,设计 网 页 中 标签 .文本 框 、 命 令 按 
钮 , 单 选 按钮 和 列表 框 的 统一 外 观 的 外 观 文件 ,其 编辑 内 容 如 下 (只 输入 粗 体 部 分 ,其 他 注释 内 
容 由 系统 自动 生成 ) : 


<% —— 


默认 的 外 观 模 板 . 以 下 外 观 仅 作为 示例 提供 。 
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1. 命名 的 控件 外 观 。SkinId 的 定义 应 唯一 ,因为 在 同一 主题 中 不 允许 一 个 控件 类 型 有 重复 的 SkinId。 
<asp:GridView runat = "server" SkinId= "gridviewSkin" BackColor = "White"” > 
<AlternatingRowStyle BackColor = "Blue" /> 
</asp:GridView > 
2. 默认 外 观 .未 定义 SkinId。 在 同一 主题 中 每 个 控件 类 型 只 允许 有 一 个 默认 的 控件 外 观 。 
< asp:Label runat ="server" style="color: #FFOOFF; font- size: medium; 
font - weight: 700; font - family: 仿宋 " /> 
< asp:TextBox runat = " server" style = "font - size: small; font - weight: 700; 
font - family: 宋体 " /> 
< asp:Button runat = " Server”style = "color: #FF0000; font - size: medium; 
font - weight: 700; font - family: 黑体 " /> 
<asp:RadioButton runat = " server" style=" font- family: 幼 圆 ; font - size: medium; 
color: #800080; font - style: italic; font— weight: bold;" /> 
<asp:ListBox runat = "server" style= "color: #008000; font - size:medium; 
font - weight:700; font- family: 华文 细 黑 " /> 


排序 依 扎 : 默认 全 -| 举国 搜索 已 安 半 模板 (Ctrl+ 晶 


@E BF7 siveriomi wr Bs Visualce 3 Vanlce 


用 于 定义 ASP.NET 主题 的 文件 


图 9.2 “添加 新 项 -ch9” 对 话 框 


注意 : 在 编辑 外 观 文件 时 ,Visual Studio 并 不 会 检查 其 中 的 语法 错误 。 

@ 如 果 要 建立 其 他 的 主题 ,在 “解决 方案 资源 管理 器 "中 右 击 App_Themes, 在 弹出 的 快 
捷 菜单 中 选择 “添加 | 添加 新 项 ”命令 ,打开 “添加 新 项 -ch9” 对 话 框 ,选择 “外观 文 件 ” 模 板 , 例 如 
为 其 命名 SkinFilel. skin, 单 击 “ 添 加 ”按钮 即 建立 另 一 个 主题 。 将 新 建 主 题名 改 为 White, 这 
样 网 站 中 有 Blue 和 White 两 个 主题 ,如 图 9.3 所 示 。 

@ 在 一 个 主题 中 可 以 有 多 个 外 观 文件 。 在 一 个 主题 中 创建 另 一 个 外 观 文件 的 方法 是 右 
击 主题 名 Blue, 在 弹出 的 快捷 菜单 中 选择 “添加 | 添加 新 项 "命令 ,打开 “添加 新 项 -ch9” 对 话 框 ， 
选择 “外 观 文件 ”模板 ,例如 指定 外 观 文件 名 SkinFile2. skin, 单 击 “ 添 加 ”按钮 为 Blue 主题 添加 
另 一 个 外 观 文件 SkinFile2. skin, 如 图 9.4 所 示 。 

@ 再 添加 一 个 用 于 网 页 HTML 文字 标记 的 样式 表 , 右 击 App_Themes, 在 弹出 的 快捷 菜 
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惠 素 解决 方 室 资 源 管 理 丢 (Chrl+;) Pp 控 率 解决 方 室 咨 源 答 理 乱 (Ctrl+;) Pp 
同 解 块 方案 “ch9”(1 个 项 目 ) 财 总 块 方案 “ch9”(1 个 项 目 ) 
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4 国 App_Themes 4 词 App Themes 
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Hr 4 国 White 
n 本 rn A SkinFilelLskin 
T WwW: 
昌 Web.Debug.config nar 
图 9.3 建立 另 一 个 主题 White 图 9.4 建立 另 一 个 外 观 文件 


单 中 选择 “添加 | 样式 表 ” 命 令 , 采 用 默认 文件 名 StyleSheet ,其 代码 如 下 : 


.html - stylel { 
font - family: 楷体 ; 
font - weight: bold; 
font - size: medium; 
color: 井 0000FF; 
text ~- align:center; 


} 

这 样 在 App_Themes 目录 下 出 现 了 一 个 StyleSheet. css 样式 表 文 件 , 主 要 用 于 网 页 中 
HTML 标记 的 格式 化 。 

说 明 : 在 Visual Studio 中 创建 外 观 文件 的 操作 方式 有 多 种 ,上 面 给 出 的 只 是 其 中 的 一 种 方式 。 

2. 主题 文件 的 外 观 标记 设计 

设计 外 观 标记 的 一 般 过 程 如 下 : 

@ 总 结 网 站 开发 中 常用 控件 的 外 观 ,在 一 个 临时 网 页 中 设计 这 些 类 型 的 控件 ,并 设置 好 
它们 通用 的 外 观 ,如 字体 .颜色 ,边框 等 。 

@ 创建 外 观 文件 。 

@ 进入 该 网 页 的 源 视图 ,将 这 些 控 件 的 HTML 代码 复制 到 该 外 观 文件 中 ,不 包括 二 html 二 、 
<<body>、 一 br> 等 标记 。 

@ 从 该 外 观 文件 中 删除 这 些 控件 的 行为 属性 ,如 ID Enabled 等 。 

@ 保存 该 外 观 文件 。 

3. 主题 文件 的 组 织 方式 

以 外 观 文 件 为 例 , 常 见 的 组 织 方式 有 以 下 4 种。 

(1) 无 组 织 

将 一 个 网 站 中 所 有 控件 的 属性 设置 放 在 一 个 外 观 文件 中 ,初学 者 或 小 型 网 站 可 以 采用 这 
种 方式 。 例 如 ,前 面 的 SkinFile. skin 外 观 文件 就 是 无 组 织 方式 。 

(2) 根据 控件 类 型 组 织 

将 同一 类 型 控件 的 所 有 属性 设置 放 在 一 个 外 观 文件 中 ,每 种 类 型 的 控件 对 应 一 个 外 观 文 
件 。 例 如 ,将 网 页 中 所 有 的 Button 外 观 标记 放 到 一 个 外 观 文件 中 : 


<asp:Button … /> 
<asp:Button SkinID = "buttonskin1”… /> 
<asp:Button SkinID = "buttonskin2”… /> 
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而 将 网 页 中 所 有 的 TextBox 外 观 标记 放 到 另 一 个 外 观 文件 中 ,如 此 等 等 。 

(3) 根据 SkinID 组 织 

将 具有 相同 SkinID 属性 的 属性 设置 放 在 一 个 外 观 文 件 中 ,每 个 SkinID 属性 值 对 应 一 个 
外 观 文件 。 例 如 ,将 网 页 中 所 有 的 SkinID 属性 为 “skinidl1” 的 外 观 标记 放 到 一 个 外 观 文 
件 中 : 


<asp:TextBox SkinID = skinidl" .… /> 
<asp:Button SkinID = " skinidl" … /> 


而 将 网 页 中 所 有 的 SkinID 属性 为 “skinid2” 的 外 观 标 记 放 到 另 一 个 外 观 文件 中 ,如 此 

(4) 根据 网 页 组 织 

将 网 页 中 每 个 网 页 的 属性 设置 放 在 一 个 外 观 文件 中 ,每 个 网 页 对 应 一 个 外 观 文件 ,这 种 方 
式 很 少 使 用 。 


9.1.3 应 用 主题 
1. 指定 主题 


常见 的 指定 主题 的 方式 有 以 下 几 种 。 
(1) 设置 网 页 的 Theme 属性 指定 主题 


属性 -x 


| DOcUMENT - 将 网 页 的 Theme 属性 设置 为 指定 的 主题 。 其 操作 是 
le ”在 属性 窗口 中 指定 DOCUMENT 的 Theme 属性 为 指定 的 
a 主题 ,如 图 9.5 所 示 。 这 样 网 页 的 页 面 指 令 自 动 变 为 : 
a <% @Page Theme = "Blue" … 和 > 
弛 时 用户 也 可 以 直接 在 页 面 指令 中 添加 上 述 粗 体 属性 。 
一 说 明 : 这 种 方式 指定 主题 的 效果 在 设计 时 不 会 显 
Ue 时 现 ,只 有 在 网 页 运行 时 外 观 文件 的 效果 才 显 现 出 来 。 另 
Theme 一 方面 ,由 于 Theme 属性 在 网 页 的 生命 周期 中 应 用 的 时 
间 较 晚 ,所 以 它 能 有 效 地 重 写 为 单个 控件 自 定义 的 任何 
属性 。 


图 9.5 指定 网 页 的 Theme 属性 
【 例 9.1】 设计 一 个 WebForml 网 页 ,其 功能 是 说 明 


CSS 和 外 观 文件 中 默认 外 观 标 记 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 在 ch9 网 站 中 添加 一 个 代码 隐藏 页 模型 的 WebForml. aspx 的 空 网 页 。 

@ 进入 设计 视图 ,从 “解决 方案 资源 管理 器 ”中 将 StyleSheet, css 样式 表 文 件 拖 放 到 网 页 
设计 界面 中 ,这 时 源 视 图 代码 中 会 自动 出 现 如 下 链接 该 样式 表 文 件 的 代码 ; 


<1link href = "App_Themes/StyleSheet. css" rel = "stylesheet" type = "text/css" /> 


再 设置 网 页 文档 的 Theme 属性 为 Blue。 

@ 本 网 页 的 设计 界面 如 图 9. 6 所 示 , 其 中 有 两 个 HTML 标记 、 两 个 文本 框 (TextBoxl 和 
TextBox2) ,一 个 命令 按钮 Button1( 其 Text 属性 设置 为 “确定 ”) 和 一 个 标签 Labell( 其 Text 
设置 为 空 )。 从 属性 窗口 指定 二 DIV 二 的 class 属性 为 html-stylel (在 StyleSheet. css 样式 表 
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文件 中 定义 ), 网 页 设计 界面 变 为 如 图 9.7 所 示 。 


ss | 子 3: 站 | | 
姓名， | 共 名 : | 
EE | [| | 
WU i 
4 >» co | » 
sat ] 四 拆 分 |。 源 | [ <asp:Butto|>] 设计 |]s 拆 分 |。 源 | [4] <aspiTexta| 
9.6 WebForml 网 页 设计 界面 一 9.7 WebForml 网 页 设计 界面 二 


@ 在 该 网 页 上 设计 如 下 事件 过 程 : 
protected void Buttonl1 Click(object sender, EventArgs e) 
{ Labell.Text = "输入 的 数据 如 下 :"” + "<br>"; 
Labell. Text += "学 号 :"” + TextBoxl. Text; 
Labell. Text += " 姓名 :" + TextBox2. Text; 
} 
@ 单 击 工具 栏 中 的 上 Imternet Explorer 按钮 运行 本 网 页 ,在 两 个 文本 框 中 分 别 输 入 “106” 和 
“ 王 华 ”, 单 击 “ 确 定 ” 命 令 按 钮 ,其 结果 如 图 9.8 所 示 。 对 比 设计 界面 和 运行 界面 ,用 户 从 中 可 
以 看 到 主题 的 作用 。 
说 明 : 本 例 中 设置 网 页 的 主题 为 Blue, 并 没有 指定 每 
个 控件 的 SkinID 属性 ,所 以 各 类 控件 都 使 用 该 主题 下 外 
观 文件 中 的 默认 外 观 标 记 。 
(2) 在 代码 中 指定 主题 
可 以 在 代码 中 为 本 网 页 指定 主题 ,但 需要 放 在 Page 
PreInit 事件 处 理 过 程 中 才 会 生效 ,其 一 般 格式 如 下 : 


protected void Page_PreInit() 输入 的 数据 如 下 : 
{ 学 号 :106 姓名 : 王 华 


Page. Theme = "主题 名 "; 


} 


(3) 在 Web. config 文件 中 指定 主题 
与 前 两 种 方法 相 比 ,这 是 一 种 一 劳 永 逸 的 方法 ,只 需 在 Web. config 文件 中 的 二 pages 二 节 
中 定义 Theme 属性 便 可 应 用 于 整个 网 站 。 例 如 : 


<configuration> 

< systenm. web > 

<pages Theme = "主题 名 "></pages> 

</system. web > 
</configuration> 
(4) 设置 网 页 的 StyleSheetTheme 属性 指定 主题 
将 网 页 的 StyleSheetTheme 属性 设置 为 指定 的 主题 ,这 样 指定 的 主题 称 为 样式 表 主 题 。 

其 操作 是 在 属性 窗口 中 指定 DOCUMENT 的 StyleSheetTheme 属性 为 指定 的 主题 ,如 图 9.9 


所 示 。 这 样 网 页 的 页 面 指令 自动 变 为 : 


图 9.8 WebForml 网 页 运行 界面 
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<$% @Page Language = "C#" StyleSheetTheme = "Blue"”… $%> 


用 户 也 可 以 直接 在 页 面 指令 中 添加 上 述 粗 休 | 下 二 十 十 二 是 是 是 时 于 
属性 。 DOCUMENT - 

样式 表 主 题 和 Theme 属性 指定 的 主题 的 区 别 是 | ccs 
后 者 只 有 在 运行 时 外 观 才 呈现 出 来 ,而 前 者 在 设计 时 i 
外 观 便 立 即 呈 现 出 来 。 

【 例 9.2】 设计 一 个 WebForm2 网 页 ,其 功能 是 
说 明 网 页 的 StyleSheetTheme 属性 和 外 观 文件 中 命 
名 外 观 标记 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 在 ch9 网 站 中 添加 一 个 代码 隐藏 页 模型 的 
WebForm2. aspx 的 空 网 页 。 

Q@ 打开 Blue 主题 下 的 SkinFile2. skin 外 观 文 图 9.9 指定 网 页 的 StyleSheetTheme 属性 
件 , 输 入 如 下 代码 : 

<asp:TextBox runat = "server" SkinID= "textboxskin1”style = "font— size: small; 

font - weight: 700; font - family: 宋体 " /> 
<asp:TextBox runat = "server" SkinID= "textboxskin2" style= "font — size: medium; 
font - family: Arial" /> 
<asp:Button runat = "server" SkinID= "buttonskin1” style = "color: 井 FF0000; 
font - size: medium; font - weight:700; font - family: 黑体 " /> 
<asp:Button runat = "server" SkinID= "buttonskin2" BorderStyle = "Inset" 
style= "color:#FF0000; font— size: medium; font ~ weight: 700; font- family: 隶书 " /> 

@ 进入 网 页 的 设计 视图 ,从 “解决 方案 资源 管理 器 "中 将 StyleSheet. css 样式 表 文 件 拖 放 

到 网 页 设计 界面 中 ,这 时 源 视图 代码 中 会 自动 出 现 如 下 链接 该 样式 表 文 件 的 代码 : 


<1link href = "App_Themes/StyleSheet. css" rel = "stylesheet" type = "text/css" /> 


再 设置 网 页 文档 的 StyleSheetTheme 属性 为 Blue。 

@ 本 网 页 中 有 两 个 HTML 标记 ,两 个 文本 框 (TextBoxl 和 TextBox2, TextBox2 的 
TextMode 属性 设置 为 Password) 、 两 个 命令 按钮 (Buttonl 和 Button2) 和 一 个 标签 Labell( 其 
Text 设置 为 空 )。 从 属性 窗口 指定 二 DIV 放 的 class 属性 为 html-stylel 。 

将 TextBoxl 和 TextBox2 的 SkinID 属性 分 别 设置 为 textboxskinl 和 textboxskin2 ,将 
Buttonl 和 Button2 的 SkinID 属性 分 别 设置 为 buttonskinl 和 buttonskin2, 此 时 看 到 的 设计 
界面 如 图 9. 10 所 示 。 

@ 在 该 网 页 上 设计 如 下 事件 过 程 : 

protected void Buttonl_Click(object sender, EventArgs e) 


{ Labell.Text = "输入 的 数据 如 下 : <br>"; 
Labell. Text += "用 户 名 为 ”+ TextBoxl.Text + "密码 为 ”+ TextBox2. Text; 


1 


} 
protected void Button2_Click(object sender, EventArgs e) 
{ Labell.Text = ""; 

TextBoxrl. Text = ""; 

TextBox2. Text = ""; 
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@ 单 击 工具 栏 中 的 P IntermetExplorer 按钮 运行 本 网 页 ,在 两 个 文本 框 中 分 别 输入 
“User1234” 和 “1234”, 单 击 “ 确 定 ” 命 令 按钮 ,其 结果 如 图 9. 11 所 示 。 


| 

| 

确定 | [ws] | 

[Label1] | 
Rstrnt 输入 的 数据 如 下 : 

用 户 名 为 User1234 密码 为 1234 


4 » 
设计 ] 日 拆 分 | 大 | [0] <asp:sub] 


图 9.10 WebForm2 网 页 设计 界面 图 9.11 WebForm2 网 页 运行 界面 


通过 本 例 一 方面 看 到 StyleSheetTheme 属性 的 作用 ,一 旦 设置 了 该 属性 ,其 作用 在 设计 时 
就 会 显现 出 来 。 另 一 方面 看 到 命名 外 观 标 记 的 使 用 方法 , Blue 主题 有 SkinFile. skin 和 
SkinFile2. skin 两 个 外 观 文件 ,前 者 包含 默认 外 观 标记 ,后 者 包含 命名 外 观 标 记 , 由 于 这 里 设 
置 了 控件 的 SkinID 属性 ,所 以 使 用 的 是 命名 外 观 标记 。 

2. 控件 外 观 属性 的 应 用 顺序 

如 果 对 网 页 既 设 置 Theme 属性 又 设置 StyleSheetTheme 属性 , 则 按 以 下 顺序 应 用 控件 的 
属性 : 

Oz@ 应 用 StyleSheetTheme 属性 。 

@ 应 用 网 页 中 的 控件 属性 ( 重 写 StyleSheetTheme) , 即 网 页 级 重 写 。 

@ 应 用 Theme 属性 ( 重 写 控件 属性 和 StyleSheetTheme) 。 

注意 : 由 于 StyleSheetTheme 的 属性 能 被 网 页 重 写 ,而 Theme 又 能 再 次 重 写 这 些 属 性 ， 
也 就 是 说 ,两 种 都 使 用 时 Theme 属性 的 优先 级 更 高 。 实 际 上 ,两 者 用 于 不 同 的 目的 。 如 果 想 
为 控件 提供 默认 设置 , 则 应 设置 StyleSheetTheme, 即 StyleSheetTheme 能 为 控件 提供 默认 
值 ,然后 又 可 以 在 网 页 级 重 写 。 如 果 想 强制 应 用 控件 的 外 观 , 则 应 使 用 Theme 属性 ,因为 
Theme 中 的 设置 不 能 再 重 写 。 


9.1.4 禁用 主题 

1. 单个 网 页 禁用 主题 

在 网 页 的 页 面 指令 中 通过 设置 EnableTheming 属性 为 False 来 使 本 网 页 禁用 主题 ,其 一 
般 格式 如 下 : 

<% @Page EnableTheming = "主题 名 " … %$> 

2. 单个 网 页 中 的 单个 控件 禁用 主题 

如 果 要 使 网 页 的 某 个 控件 禁用 主题 ,只 需 把 这 个 控件 的 EnableTheming 属性 设置 为 
False 即 可 。 例 如 ,以 下 代码 使 得 Buttonl 控件 禁用 主题 : 


<asp:Button ID = "Button1”runat = "server" EnableThemeing = "False" /> 


注意 : 禁用 主题 只 影响 外 观 文件 的 作用 ,不 会 影响 主题 中 的 CCS 文件 的 作用 。 
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9.2 母 版 页 


用 户 在 设计 网 页 时 经 常会 遇 到 多 个 网 页 部 分 内 容 相同 的 情况 ,如 果 每 个 网 页 都 设计 一 次 ， 
显然 是 重复 劳动 且 非 常 烦琐 ,为 此 ASP.NET 提供 了 母 版 页 来 解决 这 个 问题 。 母 版 页 提供 了 
统一 管理 和 定义 网 页 的 功能 ,使 多 个 网 页 具有 相同 的 布局 风格 ,给 网 页 设计 和 修改 带 来 很 大 的 
方便 。 


9.2.1 母 版 页 和 内 容 页 


1. 母 版 页 概述 

母 版 页 是 指 其 他 网 页 可 以 将 其 作为 模板 来 引用 的 特殊 网 页 。 母 版 页 的 扩展 名 为 master。 
在 母 版 页 中 界面 被 分 为 公用 区 和 可 编辑 区 ,公用 区 的 设计 方法 与 一 般 网 页 的 设计 方式 相同 ,可 
编辑 区 用 ContentPlaceHolder 控件 预 留 出 来 ,ContentPlaceHolder 控件 起 到 占 位 符 的 作用 , 它 
在 母 版 页 中 标识 出 某 个 区 域 ,该 区 域 将 预 留 给 内 容 页 。 在 一 个 母 版 页 中 可 以 有 一 个 可 编辑 区 ， 
也 可 以 有 多 个 可 编辑 区 。 

2. 内 容 页 概述 

引用 母 版 页 的 . aspx 网 页 即 为 内 容 页 。 在 内 容 页 中 母 版 页 的 ContentPlaceHolder 控件 预 
留 的 可 编辑 区 会 被 自动 替换 为 Content 控件 ,开发 人 员 只 需 在 Content 控件 区 域 中 填充 内 容 
即 可 ,在 母 版 页 中 定义 的 其 他 标记 将 自动 出 现在 使 用 了 该 母 版 页 的 . aspx 网 页 中 。 

3, 母 版 页 和 内 容 页 的 关系 

在 客户 端 浏览 器 请 求 基于 母 版 页 的 网 页 时 ,服务 器 会 读 取 内 容 页 和 对 应 的 母 版 页 ,将 两 者 
合并 , 母 版 页 中 的 占 位 符 即 ContentPlaceHolder 控件 包含 内 容 页 中 的 内 容 , 然 后 将 最 终结 果 
发 送 给 浏览 器 。 母 版 页 和 内 容 页 的 关系 如 图 9. 12 所 示 。 

母 版 页 内 容 页 


<asp:Content> 


YY 


~ 


<asp:ContentPlaceHolder> 


图 9.12 母 版 页 和 内 容 页 的 关系 


在 某 些 情况 下 ,内 容 页 和 母 版 页 中 会 引发 相同 的 事件 。 例 如 ,两 者 都 引发 Init 和 Load 事 
件 。 引 发 事件 的 一 般 规则 是 初始 化 事件 从 最 里 面 的 控件 向 最 外 面 的 控件 引发 ,所 有 其 他 事件 
则 从 最 外 面 的 控件 向 最 里 面 的 控件 引发 。 请 记 住 , 母 版 页 会 合并 到 内 容 页 中 并 被 视 为 内 容 页 
中 的 一 个 控件 ,这 一 点 十 分 有 用 。 
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母 版 页 和 内 容 页 合并 后 所 执行 的 事件 顺序 如 下 。 


@ 母 版 页 中 包含 控件 的 Init 事件 : 先 初始 化 母 版 页 包含 的 所 有 服务 器 控件 。 

@ 内 容 页 中 包含 控件 的 Init 事件 : 初始 化 内 容 页 包含 的 所 有 服务 器 控件 。 

@ 母 版 页 的 Init 事件 : 初始 化 母 版 页 。 

@ 内 容 页 的 Init 事件 : 初始 化 内 容 页 。 

@ 内 容 页 的 Load 事件 : 加 载 内 容 页 (这 是 Page_Load 事件 ,后 跟 Page_LoadComplete 
事件 ) 。 

@ 母 版 页 的 Load 事件 : 加 载 母 版 页 (这 也 是 Page_Load 事件 ,后 跟 Page_LoadComplete 
事件 ) 。 

@ 母 版 页 中 包含 控件 的 Load 事件 : 把 母 版 页 中 的 服务 器 控件 加 载 到 网 页 中 。 

@ 内 容 页 中 包含 控件 的 Load 事件 : 把 内 容 页 中 的 服务 器 控件 加 载 到 网 页 中 。 

G@ 内 容 页 的 PreRender 事件 : 在 加 载 内 容 页 之 后 .呈现 之 前 。 

四 母 版 页 的 PreRender 事件 : 在 加 载 母 版 之 后 .呈现 之 前 。 

@@ 母 版 页 中 控件 的 PreRender 事件 : 在 加 载 母 版 页 中 控件 之 后 .呈现 之 前 。 

@ 内 容 页 中 控件 的 PreRender 事件 : 在 加 载 内 容 页 中 控件 之 后 .呈现 之 前 。 


9.2.2 创建 母 版 页 


创建 母 版 页 的 方法 与 一 般 网 页 相似 ,区 别 仅仅 是 不 能 单独 在 浏览 器 中 查看 母 版 页 ,而 必须 
通过 内 容 页 在 浏览 器 中 查看 。 下 面 通过 一 个 例子 说 明 创 建 母 版 页 的 操作 步骤 。 

【 例 9.3】 设计 一 个 母 版 页 MasterPage. master, 其 功能 是 说 明 母 版 页 的 创建 过 程 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch9 网 站 ,选择 “网 站 | 添加 新 项 "命令 ,出 现 “ 添 加 新 项 -ch9” 对 话 框 ,选中 “ 母 版 页 ” 
模板 ,保持 默认 文件 名 MasterPage. master, 如 图 9. 13 所 示 , 单 击 “ 添 加 ”按钮 。 


9.13 “添加 新 项 -ch9” 对 话 框 


@ 出 现 母 版 页 设计 界面 ,删除 其 中 自动 产生 的 ContentPlaceHolder 控件 ,插入 一 个 2X4 
的 表格 ,在 第 1 行 各 列 中 放置 4 个 HTML 标签 ,在 第 2 行 第 1 列 中 放置 一 个 Label 控件 
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Labell ,在 第 2 行 第 2 列 中 放置 一 个 ContentPlaceHolder 控件 ContentPlaceHolderl ,在 第 2 
行 第 3 列 中 放置 一 个 ContentPlaceHolder 控件 ContentPlaceHolder2 ,在 第 2 行 第 4 列 中 放置 
一 个 ListBox 控件 ListBoxl ,如 图 9. 14 所 示 。 


a 
Th lad rr : 


此 处 显示 此 处 显示 诗 ListBox 1 用 于 
诗人 照片 名 供用 户 选 择 显示 诗句 


图 9. 14 MasterPage. master 母 版 页 设计 界面 


其 中 ,公用 区 主要 有 一 个 Label 控件 Labell (用 于 显示 诗人 名 ) 和 一 个 ListBox 控件 
ListBoxl( 用 于 显示 用 户 所 选 诗 名 的 诗句 ) ,两 个 ContentPlaceHolder 控件 占用 的 地 方 在 内 容 
页 中 设计 ,分 别 用 于 放 诗 人 照片 和 诗 名 列表 (供用 户 选 择 诗 名 ) 。 

@ 进入 源 视图 ,可 以 看 到 该 母 版 页 的 代码 如 下 : 


<% @Master Language = "C 井 ”RutoEventWireup = "true" CodeFile = "MasterPage. master. cs" 
Inherits= "MasterPage" %> 
<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head runat = "server"> 
<meta http - equiv= "Content ~ Type" content = "text/html; charset = utf ~ 8"/> 
<title></title> 
<asp:ContentPlaceHolder id= "head" runat = "server"> </asp:ContentPlaceHolder > 
< style type = "text/css"> 
.auto— stylel { width: 97% ; } 
.auto— style2 { width: 127px; } 
.auto - style4 { width: 252px; } 
.auto— style5 { 
font - family: 楷体 ; 
font - weight: bold; 
font — size: medium; 
color: 井 0000FF; 
text 一 align: center; 
width: 269px; 
} 
.auto— style6 { width: 269px; } 
</style> 
< link href = "App_Themes/StyleSheet. css" rel = "stylesheet" type= "text/css" /> 
</head> 
<body style= "width: 573px"> 
<form id= "forml" runat = "server"> 
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<div> 
<table class = "auto— stylel"> 
ee 
<td class = "html - stylel"> 诗 人 </td> 
<td class = "html - stylel"> 照 片 </td> 
<td class = "auto - style5"> 选 择 诗歌 名 </td> 
<td class = "html - stylel"> 诗 歌 </td> 
</tr> 
<tr> 
<td class = "auto— style2"> 
<asp:Label ID = "Label1" runat = "server"></asp:Label > 
</td> 
<td class = "auto— style4"> 
<asp:ContentPlaceHolder ID = "ContentPlaceHolder1" 
runat = "server"> 
</asp:ContentPlaceHolder > 
</td> 
<tdclass= "auto— style6"> 
<asp:ContentPlaceHolder ID = "ContentPlaceHolder2" 
runat = "server"> 
</asp:ContentPlaceHolder > 
</td> 
<td> 
<asp:ListBox ID= "ListBox1l" runat = "server" Height = "184px" 
Width= "174px"></asp:ListBox> 
</td> 
</tr> 
</table> 
</div> 
</form> 
</body> 
</html > 


除了 将 Page 页 面 指令 改 为 Master 指令 以 及 使 用 ContentPlaceHolder 控件 外 ,上 述 代码 
与 一 般 的 网 页 十 分 类 似 。 
注意 : 母 版 页 不 支持 主题 。 


9.2.3 创建 内 容 页 


在 创建 一 个 完整 的 母 版 页 之 后 , 接 下 来 必然 根据 母 版 页 创建 内 容 页 ,主要 有 几 种 方法 ， 

。 选择 “网 站 | 添加 新 项 ”命令 来 创建 一 个 Web 网 页 ,在 创建 该 网 页 的 “添加 新 项 ”对 话 框 
中 勾 选 “选择 母 版 页 ” 复 选 框 ,然后 指定 相应 的 母 版 页 。 

。 在 解决 方案 资源 管理 器 中 右 击 某 个 母 版 页 文件 ,在 弹出 的 快捷 菜单 中 选择 “添加 内 容 
页 ”命令 。 

。 在 解决 方案 资源 管理 器 中 选中 某 个 母 版 页 文件 .然后 选择 “网 站 | 添加 内 容 页 ”命令 创 
建 一 个 Web 网 页 。 

后 两 种 方法 都 自动 创建 默认 名 称 ( 如 Default. aspx) 的 网 页 ,然后 可 以 修改 网 页 名 称 。 在 

设计 内 容 页 时 用 户 要 注意 以 下 两 点 : 

。 内 容 页 的 所 有 内 容 都 包含 在 Content 控件 , 母 版 页 中 的 ContentPlaceHolder 控件 在 内 
容 页 中 显示 为 Content 控件 。 
。 内 容 页 必须 绑 定 到 母 版 页 ,其 方式 是 在 内 容 页 的 页 面 指令 中 设置 MasterPageFile 属性 
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为 指定 的 母 版 页 。 
下 面 通过 一 个 例子 说 明 创建 内 容 页 的 操作 步骤 。 
【 例 9.4】 设计 一 个 WebForm3 网 页 ,其 功能 是 说 明 利用 母 版 页 来 创建 内 容 页 的 方法 。 
解 : 其 步骤 如 下 。 
Q@ 打开 ch9 网 站 ,在 解决 方案 资源 管理 器 中 创建 一 个 Images 目录 , 放 入 若干 图 片 文件 。 
@ 选择 “网 站 | 添加 新 项 "命令 ,出 现 “ 添 加 新 项 -ch9” 对 话 框 ,选中 “Web 窗 体 " 模 板 , 修 改 
文件 名 为 WebForm3. aspx, 勾 选 “ 选 择 母 版 页 ” 复 选 框 ,如 图 9. 15 所 示 , 单 击 “ 添 加 ”按钮 。 


9.15 添加 WebForm3. aspx 网 页 


图 出 现 如 图 9. 16 所 示 的 “选择 母 版 页 ”对 话 框 ,选中 MasterPage. master, 单 击 “ 确 定 ” 


按钮 。 


图 9. 16 “选择 母 版 页 "对话 框 


出 现 WebForm3 内 容 页 的 如 图 9. 17 所 示 的 设计 界面 ,除了 母 版 页 中 对 应 的 Content 控件 
外 ,其 他 部 分 旦 灰色 ,表示 是 只 读 不 可 编辑 的 。 
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诗人 照片 


[ContentlaceHoldal{E EY 
EL 


4 
jls 设计 | 日 拆 分 |= 源 | 


图 9.17 WebForm3 内 容 页 的 初始 设计 界面 


@ 设置 该 网 页 的 Theme 属性 为 “Blue”, 从 解决 方案 资源 管理 器 将 Images 目录 中 的 “ 李 
白 . jpg” 图 像 文件 拖 放 到 ContentPlaceHolderl 控件 中 。 然 后 向 ContentPlaceHolder2 控件 中 
添加 3 个 RadioButton 控件 (从 上 到 下 为 RadioButton1 一 RadioButton3) 和 一 个 Button 控件 
Buttonl ,修改 RadioButton1 一 RadioButton3 的 Text 属性 ,将 它们 的 GroupName 属性 均 设置 
为 sn ,并 设置 相应 的 字体 和 颜色 属性 。WebForm3 内 容 页 的 最 终 设计 界面 如 图 9. 18 所 示 。 


[Label1] 


5 设计 | 拆 分 |。 源 | [|4][<asp:ContentsContent2>| <aspButtonzButtonl> 上 


图 9.18 WebForm3 内 容 页 的 最 终 设 计 界 面 


@ 进入 网 页 的 源 视图 ,本 网 页 的 代码 如 下 : 


<% @Page Title= "" Language = "C#" MasterPageFile= "~ /MasterPage. master" 
AutoEventWireup= "true" CodeFile = "WebForm3. aspx. cs" 
Inherits = "WebForm3" Theme= "Blue"” %> 
<asp:Content ID = "Content1" ContentPlaceHolderID = "ContentPlaceHolder1l" 
Runat = " Server"> 
<p>< img src = "Images/ 李 白 . jpg" style= "height: 181px; width: 143px" /></p> 
</asp:Content > 
<asp:Content ID = " Content2”ContentPlaceHolderID = "ContentPlaceHolder2" 
Runat = "Server"> 
<asp:RadioButton ID = "RadioButton1”runat = "server”GroupName = "sn” 
Text = " 赠 孟 浩然 " /> 
<br /><br /> 
<asp:RadioButton ID= "RadioButton2" runat = "server" GroupName = "sn 
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Text = "月 下 独 酮 " /> 

<br /><br /> 

<asp:RadioButton ID= "RadioButton3" runat = "server" GroupName = "sn" 
Text=" 送 友人 " /> 

<br /><br /><br /> 

Snbsp; gnbsp; 

<asp:Button ID = "Buttonl" runat = "server" OnClick = "Button1_Click" 

Text = "确定 " style = "width: 40px" /> 
</asp:Content > 

对 该 网 页 视图 的 几 点 说 明 如 下 : 

。 内 容 页 的 源 视 图 代码 与 一 般 网 页 的 源 视 图 代码 不 同 , 不 包含 二 html>>、 二 body 过 等 
HTML 元 素 ,这 些 元 素 包含 在 母 版 页 中 。 

。 内 容 页 的 源 视 图 代码 主要 由 两 部 分 组 成 , 即 代 码头 声明 和 Content 控件 区 。 代 码头 声明 
中 页 面 指令 重要 的 属性 是 MasterPageFile( 设 置 所 绑 定 的 母 版 页 ) 和 Title( 设 置 网 页 标题 ) 
等 。Content 控件 区 中 包含 一 个 或 多 个 Content 控件 ,用 来 包含 网 页 中 的 非 公共 内 容 ， 
Content 控件 通过 ContentPlaceHolderID 属性 与 母 版 页 中 的 ContentPlaceHolder 控 
件 关联 。 


9.2.4 从 内 容 页 中 访问 母 版 页 中 的 内 容 


母 版 页 和 内 容 页 都 可 以 包含 控件 的 事件 处 理 过 程 。 对 于 控件 而 言 ,事件 是 本 地 处 理 的 , 即 
内 容 页 中 的 控件 在 内 容 页 中 引发 事件 , 母 版 页 中 的 控件 在 母 版 页 中 引发 事件 。 控件 的 事件 不 
会 从 内 容 页 发 送 到 母 版 页 ,同样 ,也 不 能 在 内 容 页 中 处 理 来 自 母 版 页 控件 的 事件 。 如 果 需 要 从 
内 容 页 访问 母 版 页 的 控件 和 属性 将 会 是 非常 困难 的 。 下 面 介 绍 从 内 容 页 中 访问 母 版 页 中 的 两 
种 方法 。 

1. 使 用 FindControl 方法 获取 母 版 页 控件 的 引用 

一 个 网 页 (无 论 是 母 版 页 、 内 容 页 还 是 普通 网 页 ) 就 是 一 个 Page 类 对 象 。Page 类 有 一 个 
Master 属性 用 于 获取 确定 页 的 整体 外 观 的 母 版 页 ,还 有 一 个 FindControl 方法 用 于 在 页 命名 
容器 中 搜索 指定 的 服务 器 控件 ,其 使 用 语法 格式 如 下 : 


public override Control FindControl(string id) 


其 中 ,参数 id 指出 要 查找 的 控件 的 标识 符 。 该 方法 的 返回 值 是 指定 的 控件 ,或 为 空 引用 
(如 果 指 定 的 控件 不 存在 )。 

因此 ,可 以 在 内 容 页 中 通过 Master. FindControl(id) 来 获取 母 版 页 中 ID 属性 为 id 的 控件 
的 引用 ,因为 @Master 页 面 指令 指出 当前 内 容 页 的 母 版 页 ,再 调用 FindControl 方法 在 母 版 页 
中 找 指定 的 控件 。 例 如 ,车 母 版 页 中 有 一 个 ID 属性 为 Labell 的 Label 控件 ,可 以 在 内 容 页 中 
设计 以 下 事件 过 程 来 设置 母 版 页 中 该 控件 的 Text 属性 : 

protected void Page_Load( object sender, EventArgs e) 

{ Label lab; // 声 明 对 象 引用 


lab = Master. FindControl("Labell") as Label; 
lab.Text = "通过 内 容 页 访问 母 版 页 控件 "; 


} 
【 例 9.5】 修改 前 面 创建 的 内 容 页 WebForm3, 实 现 诗人 李白 的 诗 名 选择 和 诗句 显示 
功能 。 


解 : 其 步骤 如 下 。 
Oa 保持 前 面 WebForm3 网 页 的 设计 不 变 , 在 其 上 设计 如 下 事件 过 程 : 
protected void Page_Load( object sender, EventArgs e) 
{ Label labl; 


labl = Master. FindControl("Labell") as Label; 
labl. Text = "李白 "; 


} 


protected void Button1_Click(object sender, EventArgs e) 

{ ListBox listl; 
listl = Master.FindControl("ListBoxl") as ListBox; 
listl. Items. Clear(); 

if (RadioButton1. Checked) 

{ ”listl. Items.Add(" 吾 爱 孟 夫子 ,风流 天 下 闻 "); 
list1. Items. Add( "红颜 弃 轩 蚁 , 白 首 甲 松 云 "); 
list1. Items. Add(" 醉 月 频 中 圣 , 迷 花 不 事 君 "); 
list1. Items. hdd(" 高 山 安 可 仰 , 徒 此 担 清 芬 "); 


} 


else if (RadioButton2.Checked) 


{ -latil. 
listl. 
listl. 
listl. 
list1. 
listl. 
listl. 


} 


Items 
Items， 
Items， 
Items， 
Items， 
Items， 
Itens 


Add(" 花 间 一 壶 酒 , 独 柄 无 相亲 "); 
.add(" 举 杯 邀 明月 ,对 影 成 三 人 ") 7 
. Add(" 月 既 不 解 饮 , 影 徒 随 我 身 "); 
. Add(" 暂 伴 月 将 影 ,行乐 须 及 春 "); 
.Add(" 我 歌 月 徘徊 ,我 舞 影 零乱 "); 
.Add(" 醒 时 同 交欢 , 醉 后 各 分 散 "); 
.add(" 永 结 无 情 游 , 相 期 避 云 汉 ") 7 


else if (RadioButton3. Checked) 

{ ”listl. Items.Add(" 青 山 横 北 郭 ,白水 绕 东城 "); 
list1. Items. hdd(" 此 地 一 为 别 , 孤 蓬 万 里 征 ")， 
list1. Items. Add(" 浮 云游 子 意 ,落日 故人 情 "); 
list1. Items. Add( "挥手 自 效 去 ,萧萧 班 马 鸣 "); 


} 
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@ 单 击 工具 栏 中 的 Pp Intemet Explorer 按钮 运行 本 网 页 ,其 初始 界面 如 图 9. 19 所 示 。 选 中 
“月 下 独 酌 ”, 单 击 “ 确 定 ” 命 令 按 钮 ,在 右边 列表 框 中 显示 对 应 的 诗句 ,如 图 9. 20 所 示 。 


图 9.19 WebForm3 网 页 运行 界面 一 
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图 9. 20 WebForm3 网 页 运行 界面 二 


2. 使 用 @MasterType 指令 获取 母 版 页 中 控件 的 引用 

如 果 要 从 内 容 页 中 访问 指定 的 母 版 页 的 成 员 , 可 通过 创建 @MasterType 指令 创建 对 此 母 
版 页 的 强 类 型 引用 。 该 指令 的 常用 形式 如 下 : 

<% @MasterType VirtualPath = " 母 版 页 文件 路 径 ”$%> 

另外 , 母 版 页 中 将 被 访问 的 属性 或 方法 声明 为 公共 成 员 。 

【 例 9.6】 设计 一 个 使 用 母 版 页 MasterPage. master 的 内 容 页 WebForm4 ,用 于 显示 诗人 
杜甫 的 相关 诗篇 ,与 WebForm3 内 容 页 的 功能 类 似 。 


解 : 其 步骤 如 下 。 
@D 打开 MasterPage. master 文件 ,添加 以 下 公共 方法 : 
public void setname( string sn) // 用 于 设置 Labell 控件 的 Text 属性 


t Labell. Text = sn; 

i void clear() // 用 于 清除 ListBoxl 控件 的 所 有 选项 
ListBox1. Itens. Clear() 

ii void add( string sz) // 用 于 向 ListBoxl 控件 中 添加 一 个 选项 
ListBox1. Items. hdd(sz) ; 


@ 采用 设计 WebForm3 内 容 页 的 方法 设计 WebForm4 内 容 页 ,设计 界面 如 图 9. 21 所 
示 。 在 源 视 图 代码 中 的 页 面 指令 下 方 添加 以 下 语句 : 


< 多 @MasterType VirtualPath = "~ /MasterPage.master"” %> 
@ 在 WebForm4 内 容 页 上 设计 如 下 事件 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
Master. setname(" 杜 甫 "); 

a void Button1_Cl ick(object sender, EventArgs e) 
Master. clear(); 
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if (RadioButton1.Checked) 

{ Master. add(" 风 急 天 高 猿 啸 哀 , 渚 清 沙 白 乌 飞 回 "); 
Master.add(" 无 边 落 木 萧萧 下 ,不 尽 长 江 滚滚 来 "); 
Master.add(" 万 里 翡 秋 常 作客 , 百年 多 病 独 登台 "); 
Master.add(" 艰 难 苦 恨 繁 霜 挨 , 濠 倒 新 停 则 酒杯 ") ; 

二 

else if (RadioButton2.Checked) 

{ Master.add(" 昔 闻 洞 庭 水 , 今 上 岳阳 楼 "); 
Master.add(" 吴 楚 东南 十 ,乾坤 日 夜 浮 "); 
Master.add(" 亲 朋 无 一 字 , 老病 有 孤 舟 "); 
Master.add(" 戎 马 关山 北 , 赁 轩 涕 泗 流 "); 

} 

else if (RadioButton3.Checked) 

{ ”Master.add(" 西 山 白 雪 三 城 成 ,南浦 清江 万 里 桥 "); 
Master.add(" 海 内 风尘 诸 弟 隔 , 天 岸 涕 泪 一 身 遥 "); 
Master.add(" 惟 将 迟暮 供 多 病 , 未 有 涓 埃 答 圣 朝 ") ; 
Master.add(" 跨 马 出 郊 时 极目 ,不 堪 人 事 日 萧条 ") 7 


诗人 


[Labell] 


虽 设 计 | 日 折 分 | 。 政 | |4][<asp:ContentsContent3>| <asp:RadioButton#RadioBut..> [| 


图 9.21 WebForm4 网 页 设计 界面 


@ 单 击 工具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,选中 * 登 岳阳 楼 ”, 单 击 “ 确 定 ” 命 令 按 
钮 ,在 右边 列表 框 中 显示 对 应 的 诗句 ,如 图 9. 22 所 示 。 


音 间 洞庭 水 ， 今 上 皇 阳 楼 
吴 楚 东南 拆 ， 乾 塌 日 夜 浮 
亲朋 无 一 字 ， 老 病 有 琉 舟 
戎 马 关山 北 ， 赁 轩 涕 泗 流 


图 9.22 WebForm4 网 页 运行 界面 
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9.2.5 和 母 版 页 的 嵌 套 

前 面 介绍 了 如 何 基 于 母 版 页 创建 内 容 页 ,实际 上 也 可 基于 母 版 页 创建 母 版 页 ,这 就 是 母 版 
页 的 嵌 套 。 如 图 9. 23 所 示 , 由 一 个 母 版 页 创建 母 版 页 1 和 母 版 页 2, 再 由 母 版 页 1 创建 内 容 
页 11 和 内 容 页 12, 由 母 版 页 2 创建 内 容 页 21 和 内 容 页 22。 


母 版 页 


母 版 页 2 


母 版 页 1 


图 9.23 和 母 版 页 的 嵌 套 


例如 ,在 创建 母 版 页 MasterPagel. master 时 指定 其 母 版 页 为 前 面 创 建 的 MasterPage. 
master, 并 在 中 间 ContentPlaceHolder2 控件 中 放置 两 个 ContentPlaceHolder 控件 ,如 图 9. 24 
所 示 。 其 源 视 图 代码 如 下 : 


<% @Master Language = "C#" MasterPageFile = "~ /MasterPage. master" 
RutoEventWireup = "true" CodeFile = "MasterPagel. master. cs" Inherits = "MasterPagel" %> 
<asp:Content ID = " Content1”ContentPlaceHolderID = "ContentPlaceHolder1" 
Runat = "Server"> 
</asp:Content > 
<asp:Content ID = " Content2”ContentPlaceHolderID = "ContentPlaceHolder2" 
Runat = "Server"> 
<p> 
< br /> gnbsp; &nbsp; gnbsp; &nbsp; Snbsp; gnbsp; 
<asp:ContentPlaceHolder ID = "ContentPlaceHolder3" runat = "server"> 
</asp:ContentPlaceHolder > 
<br /><br /> 
<asp:ContentPlaceHolder ID = "ContentPlaceHolder4" runat = "server"> 
</asp:ContentPlaceHolder > 
</p> 
</asp:Content > 


在 使 用 MasterPagel. master 母 版 页 创建 内 容 页 时 ,可 以 在 每 个 ContentPlaceHolder 控件 
中 放置 需要 的 控件 。 
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四 
和 
5 设 + ] 四 拆 合 | 。 天 | [4][<asp:ContentsContent3>|[<p>| <asp:ContentPlaceHoldersC..> [| 


图 9.24 和 母 版 页 MasterPagel. master 的 设计 界面 


练习 题 9 


1. 简 述 主题 和 母 版 页 的 作用 。 

2. CSS 样式 表 与 主题 有 什么 区 别 ? 

3. 简 述 主题 文件 的 组 织 方式 。 

4. 简 述 主题 的 创建 和 使 用 方法 。 

5. 设置 网 页 的 Theme 属性 指定 主题 和 设置 网 页 的 StyleSheetTheme 属性 指定 主题 有 什 
么 不 同 ? 

6. 简 述 控件 外 观 属性 的 应 用 顺序 。 

7. 简 述 母 版 页 和 内 容 页 的 概念 。 

8. 简 述 母 版 页 的 创建 和 使 用 方法 。 

9. 一 个 母 版 页 可 以 作为 另 一 个 母 版 页 的 母 版 页 吗 ? 如 果 可 以 ,如 何 设计 ? 
10. 简 述 母 版 页 和 内 容 页 合并 后 所 执行 的 事件 顺序 。 


上 机 实验 题 9 


在 ch9 网 站 中 创建 一 个 MasterPage2. master 母 版 页 ,其 设计 界面 如 图 9. 25 所 示 , 再 创建 
一 个 Exper 主题 ,其 中 皮肤 文件 的 样式 如 下 : 


<asp:Button runat = "server" 

style= "color: 提 FF0000; font- size: medium; font— weight: 700; font - family: 黑体 " /> 
<asp:Label runat = "server" 

style= "color: #3FFOOFF; font— size: medium; font — weight: 700; 

font - family: 仿宋 ;width:100%" /> 


EE 


图 9.25 母 版 页 的 设计 界面 
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添加 一 个 名 称 为 Experment9 的 网 页 ,以 MasterPage2. master 为 母 版 页 ,用 户 输 入 学 号 和 
姓名 , 单 击 “ 确 定 ” 命 令 按钮 后 的 界面 如 图 9. 26 所 示 。 


手 号 
姓名 | 陈 3 


输入 信息 : - 
学 号 : 601 姓名 : 陈 斌 


图 9.26 上 机 实验 题 6 网 页 的 运行 界面 


CHAP ER 10 


站 点 导航 控件 第 10 章 


对 于 较 大 型 的 网 站 ,可 以 利用 ASP.NET 站 点 导航 控件 实现 站 点 导航 。 站 
点 导航 的 作用 就 像 城市 道路 的 路 标 , 使 用 户 在 操作 时 清楚 地 了 人 解 自己 所 处 的 位 
置 。 本 章 介绍 利用 站 点 导航 控件 实现 站 点 导航 设计 。 

本 章 学 习 要 点 : 

回 掌握 站 点 导航 的 基本 概念 。 

回 掌握 站 点 地 图 的 创建 和 使 用 方法 。 

回 掌握 站 点 导航 控件 TreeView、Menu 和 SiteMapPath 的 使 用 方法 。 

回 灵 活 使 用 站 点 导航 控件 实现 大 型 网 站 的 导航 设计 。 


10.1 ASP.NET 站 点 导航 概述 


使 用 ASP.NET 站 点 导航 功能 可 以 为 用 户 导 航 站 点 提供 一 致 的 方法 。 随 
着 站 点 内 容 的 增加 以 及 用 户 在 站 点 内 来 回 移动 网 页 ,管理 所 有 的 链接 可 能 会 变 
得 比较 困难 。ASP.NET 站 点 导航 使 用 户 能 够 将 指向 所 有 网 页 的 链接 存储 在 一 
个 中 央 位 置 ,并 在 列表 中 呈现 这 些 链接 ,或 用 一 个 特定 Web 服务 器 控件 在 每 个 
网 页 上 呈现 导航 菜单 。 


10.1.1 站 点 导航 的 功能 


若 要 为 网 站 创建 一 致 的 ,容易 管理 的 导航 解决 方案 ,可 以 使 用 ASP. NET 
站 点 导航 。ASP.NET 站 点 导航 提供 下 列 功能 : 

。 可 以 使 用 站 点 地 图 描述 站 点 的 逻辑 结构 ,接着 通过 在 添加 或 移 除 页 面 时 
修改 站 点 地 图 (而 不 是 修改 所 有 网 页 的 超 链 接 ) 来 管理 页 导航 。 
可 以 使 用 ASP.NET 导航 控件 在 网 页 上 显示 导航 菜单 ,导航 菜单 以 站 点 
地 图 为 基础 。 
可 以 以 代码 方式 创建 自 定义 导航 控件 或 修改 在 导航 菜单 中 显示 的 信息 
的 位 置 。 
可 以 配置 用 于 在 导航 菜单 中 显示 或 隐藏 链接 的 访问 规则 。 
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。 可 以 创建 自 定 义 站 点 地 图 提供 程序 ,以 便 使 用 自己 的 站 点 地 图 后 端 (如 存储 链接 信息 
的 数据 库 ) ,并 将 提供 程序 插入 到 ASP.NET 站 点 导航 系统 。 
10.1.2 站 点 导航 的 工作 方式 


通过 ASP.NET 站 点 导航 可 以 按 层次 结构 描述 站 点 的 布局 。 例 如 ,一 个 大 学 网 站 共有 11 
页 ,其 布局 如 下 : 


和 华 大 学 
院 系 设置 
计算 机 学 院 
电子 信息 学 院 
数学 学 院 
物理 学 院 


职能 部 门 
教务 处 
财务 处 
学 生 工作 处 
科技 处 


若 要 使 用 站 点 导航 , 先 创建 一 个 站 点 地 图 或 站 点 的 表示 形式 ,可 以 用 XML 文件 描述 站 点 
的 层次 结构 ,也 可 以 使 用 其 他 方法 。 在 创建 站 点 地 图 后 ,可 以 使 用 站 点 导航 控件 在 ASP. NET 
页 上 显示 导航 结构 。 

默认 的 ASP.NET 站 点 地 图 提供 程序 会 加 载 站 点 地 图 数据 作为 XML 文档 ,并 在 应 用 程 
序 启 动 时 将 其 作为 静态 数据 进行 缓存 。 在 更 改 站 点 地 图 文件 时 ,ASP.NET 会 重新 加 载 站 点 
地 图 数据 。 


10.1.3 几 种 站 点 导航 控件 


创建 一 个 反映 站 点 结构 的 站 点 地 图 只 完成 了 ASP.NET 站 点 导航 系统 的 一 部 分 ,导航 系 
统 的 另 一 部 分 是 在 ASP.NET 网 页 中 显示 导航 结构 ,这 样 用 户 就 可 以 在 站 点 内 轻松 地 移动 。 
用 户 通过 使 用 下 列 ASP. NET 站 点 导航 控件 可 以 轻松 地 在 页 面 中 建立 导航 信息 。 

。 TreeView: 此 控件 显示 一 个 树 状 结构 或 菜单 ,让 用 户 可 以 遍历 访问 站 点 中 的 不 同 页 

面 。 单 击 包含 子 结 点 的 结 点 可 将 其 展开 或 折 丢 。 
。 Menu: 此 控件 显示 一 个 可 展开 的 菜单 ,让 用 户 可 以 遍历 访问 站 点 中 的 不 同 页 面 。 将 光 
标 悬 停 在 菜单 上 时 ,将 展开 包含 子 结 点 的 结 点 。 

。 SiteMapPath: 此 控件 显示 导航 路 径 ( 也 称 为 当前 位 置 或 页 

眉 导航 ), 向 用户 显示 当前 页 面 的 位 置 , 并 以 链接 的 形式 显 A 指针 


Menu 


示 返 回 主页 的 路 径 。 此 控件 提供 了 许多 可 供 自 定义 链接 的 
外 观 的 选项 。 

所 有 站 点 导航 控件 均 位 于 工具 箱 的 “导航 ”选项 卡 中 ,如 图 10. 1 

所 示 , 可 以 像 其 他 服务 器 控件 一 样 使 用 。 生生 作 


遇 
SiteMapPath 
和 三 TreeView 


第 10 章 ”站 点 导航 控 


10.2 站 点 地 图 


站 点 地 图 是 一 种 以 . sitemap 为 扩展 名 的 标准 XML 文件 ,主要 为 站 点 导航 控件 提供 站 点 
层次 结构 信息 ,默认 名 为 Web. sitemap。 

下 面 通过 一 个 示例 说 明 创建 站 点 地 图 的 过 程 。 

【 例 10.1】 在 D 盘 ASP.NET 目录 中 建立 一 个 ch10 的 子 目录 ,将 其 作为 网 站 目录 ,创建 
一 个 表示 前 面 所 列 的 大 学 网 站 层次 结构 的 站 点 地 图 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012 。 

@ 选择 “文件 | 新 建 | 网 站 ”命令 ,出 现 * 新 建 网 站 "对话 框 , 然 后 选择 “ASP.NET 空 网 站 ” 
模板 ,选择 "Web 位 置 ” 为 “文件 系统 ”, 单 击 “ 浏 览 ” 按 钮 ,选择 “D:\ASP.NET\ch10” 目 录 , 单 击 
“确定 ”按钮 ,创建 一 个 空 的 网 站 ch10。 

@ 选择 “网 站 | 添加 新 项 "命令, 出现 “添加 新 项 -ch10” 对 话 框 ,在 中 间 列 表 中 选择 “站 点 地 
图 ”模板 ,保持 默认 名 称 为 web. sitemap( 只 有 名 称 为 web. sitemap 的 站 点 地 图 才 会 被 自动 加 
载 ,并 且 必 须 出 现在 网 站 的 根 目 录 中 ), 如 图 10. 2 所 示 , 单 击 “ 添 加 ”按钮 。 


| 
: 


钊 幸 已 安装 模板 (Ctrl+ 日 


类 型 : Visual C# 


| 
昌 
昕 
另 
四 
SE 
I 


” 


口 将 代码 放 在 单独 的 文件 中 (P) 
口 书生 版 RO) 


图 10.2 “添加 新 项 -ch10” 对 话 框 
@ 出 现 站 点 地 图 的 编辑 窗口 ,编辑 该 站 点 地 图 包含 的 内 容 如 下 : 


<?xml version = "1.0" encoding = "utf ~- 8" ?> 
< siteMap xmlns = "http://schemas. microsoft. com/AspNet/SiteMap - File—1.0"> 
< siteMapNode url = "WebForm3.aspx" title = "中 华 大 学 " description= ""> 
< siteMapNode url = "school. aspx" title = " 院 系 设置 " description = ""> 
< siteMapNode url = "school1.aspx" title= "计算 机 学 院 " description="" /> 
< siteMapNode url = "schoo12.aspx" title= "电子 信息 学 院 " description="" /> 
< siteMapNode url = "schoo13.aspx" title= "数学 学 院 " description="" /> 
< siteMapNode url = "schoo14.aspx" title= "物理 学 院 " description="" /> 
</siteMapNode > 
< siteMapNode url = "depart. aspx" title = "职能 部 门 " description = ""> 
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< siteMapNode url = "depart1.aspx" title= "教务 处 " description="" /> 
< siteMapNode url = "depart2.aspx" title= "财务 处 " description="" /> 
< siteMapNode url = "depart3.aspx" title= "学 生 工作 处 " description = "" /> 
< siteMapNode url = "depart4.aspx" title= "科技 处 " description = "" /> 
</siteMapNode > 
</siteMapNode > 
</siteMap> 


站 点 地 图 是 一 个 标准 的 XML 文件 。 其 中 ,第 一 个 标记 用 于 标识 版 本 和 编码 方式 ， 
siteMap 是 站 点 地 图 的 根 结 点 标记 ,包含 若干 个 siteMapNode 子 结 点 ,一 个 siteMapNode 子 结 
点 下 又 可 以 包含 若干 个 siteMapNode 子 结 点 ,构成 一 种 层次 结构 。 

siteMapNode 结 点 的 常用 属性 如 表 10. 1 所 示 。 

表 10.1 siteMapNode 结 点 的 常用 属性 


属 性 说 明 
url 设置 用 于 结 点 导航 的 URL 地 址 ,在 整个 站 点 地 图 文件 中 该 属性 必须 唯一 
title 设置 结 点 名 称 
description 设计 结 点 说 明文 字 
key 定义 当前 结 点 的 关键 字 
roles 定义 允许 查找 该 站 点 地 图 文件 的 角色 集合 ,多 个 角色 可 用 分 号 (;) 或 逗号 (,) 分 隔 
Provider 定义 处 理 其 他 站 点 地 图 文件 的 站 点 导航 提供 程序 名 称 ,默认 为 XmlSiteMapProvider 


siteMapFile 设置 包含 其 他 相关 SiteMapNode 元 素 的 站 点 地 图 文件 


注意 : 一 个 站 点 地 图 中 siteMapNode 结 点 的 url 属性 所 指定 的 网 页 不 能 重复 ,否则 会 造 
成 导航 控件 无 法 正常 显示 ,最 后 运行 时 产生 错误 。 


10.3 TreeView 控件 


TreeView 控件 又 称 为 树 形 导 航 控件 ,对 应 System. Web. UI. WebControls 命名 空间 中 的 
TreeView 类 。 它 的 显示 类 似 于 一 棵 横向 的 树 , 可 以 展开 或 折 释 树 的 结 点 来 分 类 查看 和 管理 信 
息 , 因 其 直观 性 得 到 了 广泛 的 应 用 。 

TreeView 控件 由 结 点 组 成 。 树 中 的 每 个 项 都 称 为 一 个 结 点 , 它 由 一 个 TreeNode 对 象 表 
示 。 结 点 类 型 的 定义 如 下 : 

。 包含 其 他 结 点 的 结 点 称 为 父 结 点 (ParentNode) 。 

。 被 其 他 结 点 包含 的 结 点 称 为 子 结 点 (ChildNode) 。 

。 没有 子 结 点 的 结 点 称 为 叶 结 点 (LeafNode) 。 

不 被 其 他 任何 结 点 包含 同时 是 所 有 其 他 结 点 的 上 级 的 结 点 是 根 结 点 (RootNode) 。 

一 个 结 点 可 以 同时 是 父 结 点 和 子 结 点 ,但 是 不 能 同时 为 根 结 点 、 父 结 点 和 叶 结 点 。 结 点 为 
根 结 点 、 父 结 点 还 是 叶 结 点 决定 着 结 点 的 几 种 可 视 化 属性 和 行为 属性 。 

尽管 通常 的 树 结构 只 具有 一 个 根 结 点 ,但 是 TreeView 控件 允许 向 树 结构 中 添加 多 个 根 
结 点 。 如 果 要 在 不 显示 单个 根 结 点 的 情况 下 显示 项 列表 ,这 种 控件 就 非常 有 用 。 


10.3.1 TreeNode 类 


TreeView 控件 中 的 一 个 结 点 就 是 一 个 TreeNode 类 对 象 。TreeNode 类 的 常用 属性 如 
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表 10. 2 所 示 ,常用 方法 如 表 10. 3 所 示 。 


表 10.2 TreeNode 类 的 常用 属性 及 其 说 明 
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属 性 说 明 
Checked 获取 或 设置 一 个 值 , 该 值 指示 结 点 的 复 选 框 是 否 被 选中 
ChildNodes 获取 TreeNodeCollection 集合 ,该 集合 包含 当前 结 点 的 第 一 级 子 结 点 
Depth 获取 结 点 的 深度 
Expanded 获取 或 设置 一 个 值 ,该 值 指示 是 否 展开 结 点 


lmageToolTip 
lmageUrl 
NavigateUrl 
Parent 
Selected 
ShowCheckBox 
Target 

Text 

ToolTip 
Value 
ValuePath 


获取 或 设置 在 结 点 旁边 显示 的 图 像 的 工具 提示 文本 

获取 或 设置 结 点 旁 显 示 的 图 像 的 URL 

获取 或 设置 单 击 结 点 时 导航 到 的 URL 

获取 当前 结 点 的 父 结 点 

获取 或 设置 一 个 值 , 该 值 指示 是 否 选 择 结 点 

获取 或 设置 一 个 值 , 该 值 指示 是 否 在 结 点 旁 显示 一 个 复 选 框 
获取 或 设置 用 来 显示 与 结 点 关联 的 网 页 内 容 的 目标 窗口 或 框架 
获取 或 设置 为 TreeView 控件 中 的 结 点 显示 的 文本 

获取 或 设置 结 点 的 工具 提示 文本 


获取 或 设置 用 于 存储 有 关 结 点 的 任何 其 他 数据 (如 用 于 处 理 回 发 事件 的 数据 ) 的 非 显 示 值 


获取 从 根 结 点 到 当前 结 点 的 路 径 


表 10.3 TreeNode 类 的 常用 方法 及 其 说 明 


方 法 说 明 
Collapse 折合 当前 树 结 点 
CollapseAll 折合 当前 结 点 及 其 所 有 子 结 点 
Expand 展开 当前 树 结 点 
ExpandAll 展开 当前 结 点 及 其 所 有 子 结 点 
Select 选择 TreeView 控件 中 的 当前 结 点 
ToggleExpandState 切换 结 点 的 展开 和 折 秋 状态 


每 个 TreeView 对 象 都 具有 一 个 Text 属性 和 一 个 Value 属性 。Text 属性 的 值 显 示 在 
TreeView 控件 中 ,而 Value 属性 用 于 存储 有 关 结 点 的 任何 其 他 数据 ,例如 传递 到 与 该 结 点 相 
关联 的 回 发 事件 的 数据 。 在 TreeView 控件 中 , 结 点 ( 即 TreeView 对 象 ) 可 以 处 于 以 下 两 种 状 
态 之 一 : 选 定 状态 和 导航 状态 。 在 默认 情况 下 会 有 一 个 结 点 处 于 选 定 状态 (该 结 点 的 Selected 
属性 为 True) 。 若 要 使 一 个 结 点 处 于 导航 状态 , 需 将 该 结 点 的 NavigateUrl 属性 值 设 置 为 空 


字符 串 以 外 的 值 ; 
字符 串 。 
TreeNode 类 


若 要 使 一 个 结 点 处 于 选 定 状 态 , 需 将 该 结 点 的 NavigateUrl 


提供 了 以 下 构造 函数 : 


public TreeNode( ) 

public TreeNode (string text) 

public TreeNode (string text, string value) 

public TreeNode (string text, string value, string imageUr1l) 
public TreeNode (string text, string value string imageUr], string navigateUr], string target) 


其 中 ,参数 text 指定 TreeView 控件 中 的 结 点 显示 的 文本 。value 指定 与 结 点 关联 的 补充 
数据 ,如 用 于 处 理 回 发 事件 的 数据 。imageUrl 指定 结 点 旁 显示 的 图 像 的 URL。navigateUrl 


属性 值 设置 为 空 
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指定 单 击 结 点 时 链接 到 的 URL。target 指定 单 击 结 点 时 用 来 显示 链接 到 的 网 页 内 容 的 目标 
窗口 或 框架 。 


10.3.2 TreeView 控件 的 属性 、 方 法 和 事件 


1. TreeView 控件 的 属性 
TreeView 控件 的 常用 属性 及 其 说 明 如 表 10.4 所 示 , 下 面 介绍 几 个 主要 的 属性 。 


表 10.4 TreeView 控件 的 常用 属性 及 其 说 明 


属 性 说 明 
CheckedNodes 获取 TreeNode 对 象 的 集合 ,这 些 对 象 表示 在 TreeView 控件 中 显示 的 选中 了 复 选 
框 的 结 点 
DataSourceID 设置 数据 源 对 象 ,如 指定 为 站 点 地 图 和 XML 文件 
ExpandDepth 获取 或 设置 第 一 次 显示 TreeView 控件 时 所 展开 的 层次 数 
lmageSet 获取 或 设置 用 于 TreeView 控件 的 图 像 组 
LevelStyles 获取 Style 对 象 的 集合 ,这 些 对 象 表 示 树 中 各 个 级 别 上 的 结 点 样式 
Nodelndent 获取 或 设置 TreeView 控件 的 子 结 点 的 缩 进 量 (以 像素 为 单位 ) 
Nodes 获取 或 设置 TreeNode 对 象 的 集合 , 它 表示 TreeView 控件 中 的 结 点 
NodeStyle 获取 对 TreeNodeStyle 对 象 的 引用 ,该 对 象 用 于 设置 TreeView 控件 中 结 点 的 默认 外 观 
NodeWrap 获取 或 设置 一 个 值 , 它 指示 空间 不 足 时 结 点 中 的 文本 是 否 换行 
RootNodeStyle 获取 对 TreeNodeStyle 对 象 的 引用 ,该 对 象 用 于 设置 TreeView 控件 中 根 结 点 的 外 观 
SelectedNode 获取 表示 TreeView 控件 中 选 定 结 点 的 TreeNode 对 象 
SelectedValue 获取 选 定 结 点 的 值 


ShowCheckBoxes 获取 或 设置 一 个 值 , 它 指示 哪些 结 点 类 型 将 在 TreeView 控件 中 显示 复 选 杠 
ShowExpandCollapse ”获取 或 设置 一 个 值 , 它 指示 是 否 显示 展开 结 点 指示 符 


ShowLines 获取 或 设置 一 个 值 , 它 指示 是 否 显示 连接 子 结 点 和 父 结 点 的 线条 
CollapseImageUzrl 可 折 登 结 点 的 指示 符 所 显示 图 像 的 URL, 此 图 像 通常 为 一 个 减 号 (一 ) 
ExpandImageUrl 可 展开 结 点 的 指示 符 所 显示 图 像 的 URL, 此 图 像 通常 为 一 个 加 号 (十 ) 


LinelmagesFolder 包含 用 于 连接 父 结 点 和 子 结 点 的 线条 图 像 的 目录 的 URL。ShowLines 属性 还 必须 
设置 为 True, 这 样 该 属性 才能 有 效 
NoExpandImageUrl ”不 可 展开 结 点 的 指示 符 所 显示 图 像 的 URL 


(1) DataSourceID 属性 

该 属性 指定 TreeView 控件 的 数据 源 控件 的 ID 属性 。 例 如 ,可 以 指定 与 XML 文件 绑 定 
的 XmlDataSource 控件 或 与 站 点 地 图 绑 定 的 SiteDataSource 控件 的 ID。 

(2) ExpandDepth 属性 

该 属性 获取 或 设置 第 一 次 显示 TreeView 控件 时 所 展开 的 层次 数 。 例 如 , 若 将 该 属性 设 
为 2, 则 将 展开 根 结 点 及 根 结 点 下 方 紧邻 的 所 有 子 结 点 。 

(3) SelectedNode 属性 

该 属性 返回 用 户 从 TreeView 控件 中 选 定 的 一 个 TreeNode 对 象 。 例 如 ,以 下 语句 在 标签 
Labell 中 显示 选择 结 点 的 文本 : 

Labell. Text = "选择 的 结 点 是 :" + TreeView1. SelectedNode. Text; 


(4) Nodes 属性 
Nodes 属性 是 TreeView 控件 中 所 有 结 点 的 集合 ,一 个 结 点 是 一 个 TreeNode 对 象 。 用 户 
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可 以 通过 索引 来 表示 Nodes 集合 中 的 元 素 (索引 从 零 开始 ) ,例如 : 
。 TreeViewl1. Nodes 表示 TreeViewl 控件 的 所 有 结 点 集合 。 
。 TreeViewl1. Nodes[0] 表 示 TreeView1l 控件 中 的 第 一 个 根 结 点 。 
。 TreeView1. Nodes[0]. ChildNodes 表示 TreeViewl 控件 中 第 一 个 根 结 点 的 子 结 点 
集合 。 
。 TreeView1. Nodes[0]. ChildNodes[1] 表 示 TreeViewl 控件 中 第 一 个 根 结 点 的 第 2 个 
子 结 点 。 
(5) ShowCheckBoxes 属性 
该 属性 用 于 指示 一 个 TreeView 控件 中 哪些 结 点 类 型 显示 复 选 框 。 若 要 在 TreeView 控 
件 中 提供 多 结 点 选择 支持 ,可 以 在 结 点 的 图 像 旁 边 显 示 复 选 框 , 其 取 值 及 说 明 如 表 10. 5 所 示 。 
例如 ,如 果 将 此 属性 设置 为 TreeNodeType. Parent, 则 会 为 树 中 的 每 个 父 结 点 显示 复 选 框 。 图 
10. 3 所 示 的 是 将 此 属性 设置 为 TreeNodeType. Leaf 的 结果 。 


表 10.5 ShowCheckBoxes 的 取 值 及 其 说 明 日 院 季 设置 
厂 计 算 机 学 院 
结 点 类 型 说 明 证 电子 信息 学 院 
本 机 厂 数 学 学 院 
TreeNodeTypes. All 为 所 有 结 点 显示 复 选 框 厂 物理 学 院 
TreeNodeTypes. Leaf 为 所 有 叶 结 点 显示 复 选 框 SO 
i _ 加 示 息 厂 财 务 处 
TreeNodeTypes. None 不 显示 复 选 框 三 学 生 工作 处 
TreeNodeTypes. Parent 为 所 有 父 结 点 显示 复 选 框 口 科技 处 
TreeNodeTypes. Root 为 所 有 根 结 点 显示 复 选 框 图 10.3 ShowCheckBoxes 属性 被 设置 为 


TreeNodeTypes. Leaf 时 


(6) LevelStyles 属性 

LevelStyles 属性 是 一 个 集合 ,可 作为 单个 样式 属性 (如 NodeStyle 属性 ) 的 另 一 种 方式 ， 
以 控制 树 中 各 个 级 别 上 的 结 点 样式 。 集 合 中 的 第 一 个 样式 对 应 于 树 视 图 第 一 级 中 的 结 点 的 样 
式 , 集 合 中 的 第 二 种 样式 对 应 于 树 中 第 二 级 结 点 的 样式 , 依 此 类 推 。 此 属性 最 常用 于 生成 目录 
样式 的 导航 菜单 ,在 这 种 导航 菜单 中 , 某 一 级 别 的 结 点 不 管 是 否 具有 子 结 点 都 会 有 相同 的 
外 观 。 

例如 , 若 一 个 TreeViewl 控件 有 4 级 ( 含 根 结 点 ), 以 下 代码 采用 LevelStyles 属性 设置 各 
级 的 样式 : 


<asp:TreeView ID = "TreeViewl" runat = "server" > 
<LevelStyles> 

<asp:TreeNodeStyle ChildNodesPadding = "10" 
Font -Bold = "true" 
Font 一 Size="12pt" 
ForeColor = "DarkGreen"/> 

<asp: TreeNodeStyle ChildNodesPadding= "5" 
Font ~ Bold = "true" 
Font - Size = "10pt"/> 

<asp: TreeNodeStyle ChildNodesPadding= "5" 
Font - UnderLine = "true” 
Font - Size = "10pt"/> 

<asp: TreeNodeStyle ChildNodesPadding = "10" 
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Font — Size = "8pt"/> 


</LevelStyles > 
<Nodes> 


</Nodes > 
</asp:TreeView > 
2. TreeView 控件 的 方法 
TreeView 控件 的 常用 方法 及 其 说 明 如 表 10.6 所 示 。 


表 10.6 TreeView 控件 的 常用 方法 及 其 说 明 


方 ”法 说 明 
ExpandAll 打开 树 中 的 每 个 结 点 
FindNode 检索 TreeView 控件 中 指定 值 路 径 处 的 TreeNode 对 象 


3. TreeView 控件 的 事件 
TreeView 控件 的 常用 事件 及 其 说 明 如 表 10.7 所 示 。 
表 10.7 TreeView 控件 的 常用 事件 及 其 说 明 
得 件 说 明 
SelectedNodeChanged 当选 择 TreeView 控件 中 的 结 点 时 引发 
TreeNodeCheckChanged 当 TreeView 控件 中 的 复 选 框 在 向 服务 器 的 两 次 发 送 过 程 之 间 状 态 有 所 更 改 时 引发 


TreeNodeCollapsed 当 折 笃 TreeView 控件 中 的 结 点 时 引发 

TreeNodeDataBound 当 数 据 项 绑 定 到 TreeView 控件 中 的 结 点 时 引发 

TreeNodeExpanded 当 扩 展 TreeView 控件 中 的 结 点 时 引发 

TreeNodePopulate 当 其 PopulateOnDemand 属性 被 设置 为 True 的 结 点 在 TreeView 控件 中 展开 时 引发 


10.3.3 TreeNodeCollection 类 


TreeView 控件 中 的 所 有 结 点 构成 一 个 TreeNodeCollection 类 对 象 , 也 就 是 说 ,TreeView 
控件 的 Nodes 属性 就 是 一 个 TreeNodeCollection 类 对 象 。TreeNodeCollection 类 的 常用 属性 
及 其 说 明 如 表 10.8 所 示 。 


表 10.8 TreeNodeCollection 类 的 常用 属性 及 其 说 明 


属 性 说 明 
Count 获取 TreeNodeCollection 对 象 中 的 项 数 
ltem 获取 TreeNodeCollection 对 象 中 指定 索引 处 的 TreeNode 对 象 


TreeNodeCollection 类 的 主要 方法 如 下 。 

(1) Add 方法 

该 方法 用 于 向 TreeNodeCollection 对 象 中 添加 一 个 TreeNode 对 象 。 其 使 用 格式 如 下 : 
public void Add(TreeNode child) 

其 中 ,参数 child 指出 要 添加 的 TreeNode 对 象 。 

(2) AddAt 方法 

该 方法 用 于 向 TreeNodeCollection 对 象 中 的 指定 位 置 添加 一 个 TreeNode 对 象 。 其 使 用 
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public void AddAt (int index, TreeNode child) 


其 中 ,参数 index 指出 将 在 该 处 插入 TreeNode 对 象 的 从 零 开 始 的 索引 位 置 ,child 指出 要 
添加 的 TreeNode 对 象 。 

(3) Clear 方法 

该 方法 用 于 从 TreeNodeCollection 对 象 中 移 除 所 有 TreeNode 对 象 。 其 使 用 格式 如 下 : 

public void Clear() 

(4) Contains 方法 

该 方法 指出 TreeNodeCollection 对 象 中 是 否 包含 指定 的 TreeNode 对 象 。 其 使 用 格式 
如 下 : 

public bool Contains(TreeNode c) 

其 中 ,参数 c 指出 要 查找 的 TreeNode 对 象 。 如 果 指 定 的 TreeNode 对 象 包含 在 
TreeNodeCollection 对 象 中 , 则 返回 值 为 True, 和 否则 返回 值 为 False。 

(5) IndexOf 方法 

该 方法 查找 指定 的 TreeNode 对 象 在 TreeNodeCollection 对 象 中 的 位 置 。 其 使 用 格式 
如 下 : 

public int IndexOf(TreeNode value) 


其 中 ,参数 value 指出 要 定位 的 TreeNode 对 象 。 如 果 找 到 TreeNodeCollection 中 value 
的 第 一 个 匹配 项 的 从 堆 开 始 的 索引 , 则 为 该 索引 ,和 否则 为 一 1。 

(6) Remove 方法 

该 方法 从 TreeNodeCollection 对 象 中 删除 指定 的 TreeNode 对 象 。 其 使 用 格式 如 下 : 


public void Remove(TreeNode value) 


其 中 ,参数 value 指出 要 移 除 的 TreeNode 对 象 。 

使 用 Remove 方法 可 以 从 集合 中 移 除 指 定 的 结 点 ,然后 跟 在 该 结 点 之 后 的 所 有 项 都 将 上 
移 以 填充 空白 位 置 ,同时 还 会 更 新 所 移动 的 项 的 索引 。 

(7) RemoveAt 方法 

该 方法 从 TreeNodeCollection 对 象 中 删除 指定 位 置 处 的 TreeNode 对 象 。 其 使 用 格式 
如 下 : 


public void RemoveAt( int index) 


其 中 ,参数 index 指出 要 移 除 的 结 点 的 从 零 开始 的 索引 位 置 。 

使 用 RemoveAt 方法 从 TreeNodeCollection 中 指定 的 从 零 开始 的 索引 位 置 移 除 
TreeNode 对 象 ,然后 跟 在 该 结 点 之 后 的 所 有 项 都 将 上 移 以 填充 空白 位 置 ,同时 还 会 更 新 所 移 
动 的 项 的 索引 。 


10.3.4 向 TreeView 控件 中 添加 结 点 的 方法 


向 TreeView 控件 中 添加 结 点 有 以 下 几 种 方法 。 
1. 通过 手工 方式 添加 结 点 
在 向 一 个 网 页 中 拖 放 一 个 TreeView 控件 时 会 出 现 *“TreeView 任务 ?列表 ,如 图 10.4 所 
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示 ， 从 中 选择 “编辑 结 点 ”命令 ,打开 “TreeView 结 点 编辑 器 ”对话 框 ,可 以 从 中 添加 和 删除 结 
点 ,如 图 10. 5 所 示 。 每 个 结 点 至 少 应 设置 Text 和 
Vlaue 属性 ,用 户 还 可 以 根据 需要 设置 NavigateUrl 
和 Target 属性 等 。 

另外 ,可 以 通过 选择 “TreeView 任务 ”列表 中 的 
“自动 套用 格式 ”命令 来 设置 TreeView 控件 的 内 置 
样式 ,图 10.6 所 示 的 是 套用 “项 目 符号 列表 6” 后 的 
预览 结果 。 


:treeviewz Tr 


图 10.6 “自动 套用 格式 ”对 话 框 


2. 通过 DataSourcelD 属性 设置 数据 源 控件 

ASP.NET 提供 了 SiteMapDataSource 和 XmlDataSource 两 个 服务 器 控件 ,位 于 工具 箱 
的 “数据 ”选项 卡 中 ,用 于 ASP.NET 站 点 导航 ,前 者 检索 站 点 地 图 提供 程序 的 导航 数据 ,后 者 
检索 指定 的 XML 文件 的 导航 数据 ,并 将 导航 数据 传递 到 可 显示 该 数据 的 控件 (如 TreeView 
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和 Menu 控件 )。 

例如 在 网 页 中 拖 放 一 个 TreeView 控件 后 ,再 从 工具 箱 的 “数据 ?选项 卡 中 将 
SiteMapDataSource 控件 拖 放 到 网 页 上 ,不 设置 其 任何 属性 ,只 需 将 TreeView 控件 的 
DataSourceID 设置 为 该 SiteMapDataSource 控件 的 ID 即 可 ,SiteMapDataSource 控件 会 自动 
读 取 站 点 地 图 的 数据 并 在 TreeView 控件 中 显示 。 

或 者 ,在 “TreeView 任务 "列表 中 单 击 “ 选 择 数据 源 ” 右 侧 的 画 按 钮 ,在 弹出 的 菜单 中 选择 
“新 建 数据 源 ” 命 令 , 出 现 “ 数 据 源 配 置 向 导 ” 对 话 框 ,选择 站 点 地 图 ”, 如 图 10.7 所 示 , 单 击 “ 确 
定 ” 按 钮 ,这 样 就 设置 了 TreeView 控件 的 数据 源 为 Web. sitemap 站 点 地 图 (实际 上 ,系统 自动 
创建 一 个 SiteMapDataSource 控件 ) 。 


图 10.7 设置 数据 源 类 型 为 “站 点 地 图 ” 


3. 通过 编程 方式 添加 结 点 

由 于 TreeView 控件 的 Nodes 属性 是 一 个 TreeNodeCollection 类 对 象 , 因 此 采用 Add 方 
法 向 其 中 添加 TreeNode 对 象 。 这 种 方式 可 以 在 运行 时 动态 地 增删 TreeView 控件 的 结 点 ,下 
面 通过 一 个 示例 说 明 。 

【 例 10.2】 创建 一 个 WebForml 网 页 ,采用 编程 方式 通过 TreeView 控件 显示 前 面 所 列 
的 大 学 网 站 层次 结构 。 

解 : 其 步骤 如 下 。 

@ 打开 ch10 网 站 ,添加 一 个 代码 隐藏 页 模型 的 网 页 WebForml. aspx。 

@ 其 设计 界面 如 图 10. 8 所 示 , 其 中 包含 一 个 TreeView 控件 TreeView1 .一 个 命令 按钮 
Buttonl 和 一 个 标签 Labell 。 

@ 进入 网 页 的 源 视图 ,添加 TreeViewl 控件 的 LevelStyles 属性 如 下 : 


<LevelStyles> 
<asp:TreeNodeStyle ChildNodesPadding= "10" 
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Font 一 Names = "黑体 " Font -Bold= "true" 

Font ~ Size = "16pt" ForeColor = "red"/> 
<asp: TreeNodeStyle ChildNodesPadding = "5" 

Font - Names = "楷体 " Font - Bold = "true" 

Font - Size = "14pt" ForeColor = "Blue" /> 
<asp:TreeNodeStyle ChildNodesPadding= "5" 

Font - Names = "仿宋 " Font - UnderLine = "true”" 

Font -Size = "12pt" ForeColor = " 间 660066"/> 

</LevelStyles > 


@ 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Page_ Load(object sender, EventArgs e) 
全 if (!Page. IsPostBack) 
{ TreeViewl.ShowCheckBoxes = TreeNodeTypes.Leaf | TreeNodeTypes.Parent; 

TreeView1.ExpandDepth = 2; 
TreeView1.Nodes. Clear(); 
TreeNode node = new TreeNode(" 中 华 大 学 "); 
TreeViewl. Nodes. Add( node); 
node = new TreeNode(" 院 系 设置 "); 
TreeViewl. Nodes[0].ChildNodes. Add(node); 
node = new TreeNode(" 计 算 机 学 院 "); 
TreeViewl. Nodes[0].ChildNodes[0]. ChildNodes. Add(node); 
node = new TreeNode(" 电 子 信息 学 院 "); 
TreeViewl. Nodes[0].ChildNodes[ 0]. ChildNodes. Add(node); 
node = new TreeNode(" 数 学 学 院 "); 
TreeViewl. Nodes[0].ChildNodes[ 0]. ChildNodes. Add(node); 
node = new TreeNode(" 物 理学 院 "); 
TreeView1.Nodes[0].ChildNodes[0]. ChildNodes. Add(node); 
node = new TreeNode(" 职 能 部 门 "); 
TreeViewl. Nodes[0].ChildNodes. Add(node); 
node = new TreeNode(" 教 务 处 "); 
TreeView1.Nodes[0].ChildNodes[1].ChildNodes. Add(node); 
node = new TreeNode(" 财 务 处 "); 
TreeViewl. Nodes[ 0].ChildNodes[1]. ChildNodes. Add(node); 
node = new TreeNode(" 学 生 工 作 处 "); 
TreeView1.Nodes[0].ChildNodes[1].ChildNodes. Add(node); 
node = new TreeNode(" 科 技 处 "); 
TreeViewl. Nodes[0].ChildNodes[1]. ChildNodes. Add(node); 
TreeView1. ShowLines = true; 


} 
protected void Button1_Click(object sender, EventArgs e) 
{ if (TreeViewl.CheckedNodes.Count > 0) 
{ ”Labell.Text = "您 的 选择 是 : <br >"; 
foreach (TreeNode node in TreeView1. CheckedNodes) 
Labell. Text += node.Text + "<br>"; 
} 
else 
Labell.Text = "没有 选择 任何 项 "; 
} 


回 单 击 工具 栏 中 的 Pp Internet Explorer 按钮 运行 本 网 页 ,然后 在 TreeViewl 控件 中 色 选 4 个 
选项 , 单 击 “ 确 定 ” 命 令 按 钮 ,其 结果 如 图 10.9 所 示 。 


第 10 章 ”站 点 导航 控 


ET P-o] 从 容光 
x 


mi  : 
pa 
条、 [Label1] 
日 父 级 2 
En 口才 名 从 
和 | 回 对 多 处 
- 上 口 学 生 工作 处 
4 PE 上 Lg 
[er ow | “a | [pmoneaesyes] 有 
图 10.8 WebForml 网 页 设计 界面 10.9 ”WebForml 网 页 运行 界面 


10.4 Mennu 控件 


Menu 控件 又 称 为 菜单 控件 ,对 应 System. Web. UI. WebControls 命名 空间 中 的 Menu 
类 。 该 控件 主要 用 于 创建 一 个 菜单 ,让 用 户 快速 选择 不 同 页 面 ,从 而 完成 导航 功能 。 其 使 用 方 
法 与 TreeView 控件 十 分 相似 。 

Menu 控件 由 菜单 项 (由 Menultem 对 象 表示 ) 权 组成。 顶级 (级 别 为 0) 菜单 项 称 为 根菜 
单项 ,具有 父 菜单 项 的 菜单 项 称 为 子 菜单 项 。 所 有 根菜 单项 都 存储 在 Items 集合 中 , 子 菜 单项 
存储 在 父 菜单 项 的 ChildItems 集合 中 。 


10.4.1 Menultem 类 


Menu 控件 中 的 一 个 菜单 项 就 是 一 个 Menultem 类 对 象 , MenuItem 类 的 常用 属性 如 
表 10.9 所 示 。 
表 10.9 Menultem 类 的 常用 属性 及 其 说 明 
属 性 说 明 


Childltems ”获取 该 对 象 包含 当前 菜单 项 的 子 菜单 项 

Dataltem 获取 绑 定 到 莱 单 项 的 数据 项 

DataPath 获取 绑 定 到 菜单 项 的 数据 的 路 径 

Depth 获取 菜单 项 的 显示 级 别 

ImageUrl 获取 或 设置 显示 在 菜单 项 文本 旁边 的 图 像 的 URL 

NavigateUrl 获取 或 设置 单 击 菜单 项 时 要 导航 到 的 URL 

Parent 获取 当前 菜单 项 的 父 菜单 项 

Selectable 获取 或 设置 一 个 值 ,该 值 指示 Menultem 对 象 是 否 可 选 或 “可 单 击 ” 
Selected 获取 或 设置 一 个 值 ,该 值 指示 Menu 控件 的 当前 菜单 项 是 否 已 被 选中 
Target 获取 或 设置 用 来 显示 菜单 项 的 关联 网 页 内 容 的 目标 窗口 或 框架 
Text 获取 或 设置 Menu 控件 中 显示 的 菜单 项 文本 

ToolTip 获取 或 设置 菜单 项 的 工具 提示 文本 


Value 获取 或 设置 一 个 非 显 示 值 该 值 用 于 存储 菜单 项 的 任何 其 他 数据 ,如 用 于 处 理 回 发 事件 的 数据 
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每 个 菜单 项 都 具有 Text 属性 和 Value 属性 。Text 属性 的 值 显示 在 Menu 控件 中 ,而 
Value 属性 用 于 存储 菜单 项 的 任何 其 他 数据 (如 传递 给 与 菜单 项 关联 的 回 发 事件 的 数据 )。 在 
单 击 时 ,菜单 项 可 导航 到 NavigateUrl 属性 指示 的 另 一 个 网 页 。 

注意 : 如 果菜 单项 未 设置 NavigateUrl 属性 , 则 单 击 该 菜单 项 时 Menu 控件 只 是 将 页 提交 
给 服务 器 进行 处 理 。 通 过 设置 ImageUrl 属性 也 可 选择 在 菜单 项 中 显示 图 像 。 

TreeNode 类 提供 了 以 下 构造 函数 : 


public MenuItem( ) 


public MenuItem (string text) 

public MenuItem( string text, string value) 

public MenuItem( string text, string value string imageUrl1) 

public MenuItem( string text, string value, string imageUrl, string navigateUr1l) 

public MenuItem( string text, string value, string imageUr], string navigateUr], string target) 


其 中 ,参数 text 指出 Menu 控件 中 为 菜单 项 显示 的 文本 ; value 指出 与 菜单 项 关联 的 补充 
数据 ,如 用 于 人 处理 回 发 事件 的 数据 ; imageUrl 指出 显示 在 菜单 项 中 的 文本 旁边 的 图 像 的 
URL;navigateUrl 指出 单 击 菜 单项 时 链接 到 的 URL; target 指出 单 击 菜单 项 时 显示 菜单 项 所 
链接 到 的 网 页 内 容 的 目标 窗口 或 框架 。 


10.4.2 Menu 控件 的 属性 和 事件 


1. Menu 控件 的 属性 
Menu 控件 的 常用 属性 及 其 说 明 如 表 10. 10 所 示 ,下 面 介绍 几 个 主要 的 属性 。 


表 10.10 Menu 控件 的 常用 属性 及 其 说 明 


属 性 说 明 
DataSourcelD 设置 数据 源 对 象 ,如 指定 为 站 点 地 图 和 XML 文件 
DisappearAfter 获取 或 设置 鼠标 指针 不 再 置 于 菜单 上 后 显示 动态 菜单 的 持续 时 间 
ltems 获取 MenultemCollection 对 象 ,该 对 象 包含 Menu 控件 中 的 所 有 菜单 项 
ItemWrap 获取 或 设置 一 个 值 ,该 值 指示 菜单 项 的 文本 是 否 换行 


Orientation 
PathSeparator 
Selectedltem 
SelectedValue 
StaticDisplayLevels 
Target 
LevelMenultemStyles 
LevelSelectedStyles 


获取 或 设置 Menu 控件 的 呈现 方向 

获取 或 设置 用 于 分 隔 Menu 控件 的 菜单 项 路 径 的 字符 

获取 选 定 的 菜单 项 

获取 选 定 菜单 项 的 值 

获取 或 设置 静态 菜单 的 菜单 显示 级 别 数 

获取 或 设置 用 来 显示 菜单 项 的 关联 网 页 内 容 的 目标 窗口 或 框架 

其 包含 的 样式 设置 是 根据 菜单 项 在 Menu 控件 中 的 级 别 应 用 于 菜单 项 的 

其 包含 的 样式 设置 是 根据 所 选 菜单 项 在 Menu 控件 中 的 级 别 应 用 于 该 菜单 项 的 


(1) DataSourceID 属性 
该 属性 指定 Menu 控件 的 数据 源 控件 的 ID 属性 。 例 如 ,可 以 指定 与 XML 文件 绑 定 的 
XmlDataSource 控件 或 与 站 点 地 图 绑 定 的 SiteDataSource 控件 的 ID。 


(2) Items 属性 


Items 属性 是 Menu 控件 中 所 有 菜单 项 的 集合 .一 个 菜单 项 是 一 个 Menultem 对 象 。 用 户 
可 以 通过 索引 来 表示 Items 集合 中 的 元 素 ( 索 引 从 零 开始 ) ,例如 : 
。 Menul. Items 表示 Menul 控件 的 所 有 菜单 项 集合 。 
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。 Menul. Items[0] 表 示 Menul 控件 中 的 第 一 个 菜单 项 。 

。 Menul. Items[0]. ChildItems 表示 Menul 控件 中 第 一 个 菜单 项 的 子 菜单 项 集合 。 

。 Menul. Item[0]. ChildItems[1] 表 示 Menul 控件 中 第 一 个 菜单 项 的 第 2 个 子 菜单 项 。 
(3) Orientation 属性 

该 属性 获取 或 设置 Menu 控件 的 呈现 方向 ,可 取 Horizontal( 表 示 水 平 呈 现 Menu 控件 ， 
如 图 10. 10 所 示 ) 或 Vertical( 默 认 值 ,表示 垂直 呈现 Menu 控件 ,如 图 10. 11 所 示 )。 


中 华 大 学 
中 华 大 学 “ 院 系 设置 ) 节 开 于 对 天 院 系 设置 
教务 处 教务 处 
则 务 外 
学 生 工 作 处 学 生 工作 处 
科技 处 科技 处 
图 10. 10 水 平 呈现 Menu 控件 图 10.11 垂直 呈现 Menu 控件 


(4) Target 属性 

该 属性 获取 或 设置 用 来 显示 菜单 项 的 关联 网 页 内 容 的 目标 窗口 或 框架 。Target 属性 影 
响 控件 中 的 所 有 菜单 项 。 若 要 为 单个 菜单 项 指定 一 个 窗口 或 框架 ,直接 设置 Menultem 对 象 
的 Target 属性 即 可 。 

(5) LevelMenultemStyles 属性 

LevelMenuItemStyles 属性 是 一 个 样式 集合 ,该 集合 用 来 控制 各 菜单 级 别 的 菜单 项 样 
式 。 此 集合 包含 的 样式 是 根据 菜单 项 的 菜单 级 别 应 用 于 菜单 项 的 。 该 集合 的 第 一 个 样式 
对 应 于 第 一 级 菜单 的 菜单 项 样式 ,该 集合 的 第 二 个 样式 对 应 于 第 二 级 菜单 的 菜单 项 样式 ， 


依 此 类 推 。 
例如 ,一 个 有 3 级 菜单 的 Menul 控件 的 LevelMenuItemStyles 属性 可 以 设置 如 下 : 
<Levelmenuitemstyles> 
<asp:menuitemstyle BackColor = "LightSteelBlue" ForeColor = "Black"/> 
<asp:menuitemstyle BackColor = "SkyBlue" ForeColor = "Black"/> 
<asp:menuitemstyle BackColor = "LightSkyBlue" ForeColor = "Black"/> 
</Levelmenuitemstyles> 


(6) LevelSelectedStyles 属性 

LevelSelectedStyles 是 一 个 集合 ,该 集合 用 来 控制 各 菜单 级 别 的 选 定 菜单 项 的 样式 。 此 
集合 包含 的 样式 是 根据 选 定 菜单 项 的 菜单 级 别 应 用 于 该 菜单 项 的 。 该 集合 的 第 一 个 样式 对 应 
于 第 一 级 菜单 的 选 定 菜单 项 的 样式 ,该 集合 的 第 二 个 样式 对 应 于 第 二 级 菜单 的 选 定 菜单 项 的 


例如 ,一 个 有 3 级 菜单 的 Menul 控件 的 LevelSelectedStyles 属性 可 以 设置 如 下 : 


<Levelselectedstyles> 
<asp:menuitemstyle BackColor = "Cyan" ForeColor = "Gray"/> 
<asp:menuitemstyle BackColor = "LightCyan" ForeColor = "Gray"/> 
<asp:menuitemstyle BackColor = "PaleTurquoise" ForeColor = "Gray"/> 
</Levelselectedstyles> 


2. Menu 控件 的 事件 
Menu 控件 的 常用 事件 及 其 说 明 如 表 10. 11 所 示 。 
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表 10. 11 Menu 控件 的 常用 事件 及 其 说 明 
事 件 说 明 
MenultemClick 单 击 菜单 项 时 发 生 。 此 事件 通常 用 于 将 页 上 的 一 个 Menu 控件 与 另 一 个 控件 进行 同步 


MenultemDataBound 当 菜 单项 绑 定 到 数据 时 发 生 。 此 事件 通常 用 来 在 菜单 项 呈现 在 Menu 控件 中 之 前 对 
菜单 项 进行 修改 


10.4.3 MenultemCollection 类 


Menu 控件 中 的 所 有 菜单 项 构成 一 个 MenultemCollection 类 对 象 Items, 也 就 是 说 , Menu 
控件 的 Items 属性 就 是 一 个 MenultemCollection 类 对 象 。MenultemCollection 类 的 常用 属性 
及 其 说 明 如 表 10. 12 所 示 。 


表 10. 12 MenultemCollection 类 的 常用 属性 及 其 说 明 


属 性 说 明 
Count 获取 当前 MenultemCollection 对 象 所 含 菜单 项 的 数目 
ltem 获取 当前 MenultemCollection 对 象 中 指定 索引 处 的 Menultem 对 象 


MenultemCollection 类 的 主要 方法 如 下 。 

(1) Add 方 法 

该 方法 用 于 向 MenultemCollection 对 象 中 添加 一 个 MenuItem 对 象 。 其 使 用 格式 如 下 : 

public void Rhdd(MenuItem child) 

其 中 ,参数 child 指出 要 添加 的 Menultem 对 象 。 

(2) AddAt 方 法 

该 方法 用 于 向 MenultemCollection 对 象 中 的 指定 位 置 添加 一 个 Menultem 对 象 。 其 使 用 
格式 如 下 : 


public void AddAt (int index, MenuItem child) 


其 中 ,参数 index 指出 将 在 该 处 插入 MenuItem 对 象 的 从 零 开始 的 索引 位 置 ,child 指出 要 
添加 的 Menultem 对 象 。 

(3) Clear 方法 

该 方法 用 于 从 MenultemCollection 对 象 中 移 除 所 有 Menultem 对 象 。 其 使 用 格式 如 下 : 


public void Clear () 


(4) Contains 方法 
该 方法 指出 MenultemCollection 对 象 中 是 否 包 含 指 定 的 MenuItem 对 象 。 其 使 用 格式 
如 下 : 


public bool Contains(MenuItem c) 


其 中 ,参数 c 指出 要 查找 的 Menultem 对 象 。 如 果 指 定 的 Menultem 对 象 包 含 在 
MenultemCollection 对 象 中 , 则 返回 值 为 True, 和 否则 返回 值 为 False。 

(5) IndexOf 方法 

该 方法 查找 指定 的 Menultem 对 象 在 MenuItemCollection 对 象 中 的 位 置 。 其 使 用 格式 
如 下 : 
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public int IndexOf(MenuItem value) 


其 中 ,参数 value 指出 要 定位 的 Menultem 对 象 。 如 果 找 到 MenuItemCollection 中 value 
的 第 一 个 匹配 项 的 从 零 开 始 的 索引 , 则 为 该 索引 ,否则 为 一 1 。 

(6) Remove 方法 

该 方法 从 MenultemCollection 对 象 中 删除 指定 的 MenuItem 对 象 。 其 使 用 格式 如 下 : 


public void Remove(MenuItem value) 


其 中 ,参数 value 指出 要 移 除 的 Menultem 对 象 。 

使 用 Remove 方法 可 以 从 集合 中 移 除 指定 的 结 点 ,然后 跟 在 该 结 点 之 后 的 所 有 项 都 将 上 
移 以 填充 空白 位 置 ,同时 还 会 更 新 所 移动 的 项 的 索引 。 

(7) RemoveAt 方 法 

该 方法 从 MenultemCollection 对 象 中 删除 指定 位 置 处 的 Menultem 对 象 。 其 使 用 格式 
如 下 : 


public void RemoveAt( int index) 


其 中 ,参数 index 指出 要 移 除 的 结 点 的 从 零 开 始 的 索引 位 置 。 

使 用 RemoveAt 方法 从 MenultemCollection 中 指定 的 从 零 开 始 的 索引 位 置 移 除 
MenuItem 对 象 ,然后 跟 在 该 结 点 之 后 的 所 有 项 都 将 上 移 以 填充 空白 位 置 ,同时 还 会 更 新 所 移 
动 的 项 的 索引 。 


10.4.4 向 Menu 控件 中 添加 菜单 项 的 方法 


向 Menu 控件 添加 菜单 项 有 以 下 几 种 方法 。 
1. 通过 手工 方式 添加 菜单 项 
在 向 网 页 中 拖 放 一 个 Menu 控件 时 会 出 现 * Menu 任务 "列表 ,如 图 10. 12 所 示 , 从 中 选择 
“编辑 菜单 项 ”命令 ,打开 “菜单 项 编辑 器 ”对话 框 ,可 以 从 中 添加 和 删除 菜单 项 ,如 图 10. 13 所 
示 。 每 个 菜单 项 至 少 应 设置 Text 和 Value 属性 ,用 户 还 可 以 根据 需要 设置 NavigateUrl 和 
Target 属性 等 。 
删除 菜单 项 


添 荐 (0: 
a 和 和 XX|H # 二 于 
ss | 


计算 机 洱 耽 


转换 为 DynamicHemTemplate 
转换 为 StaticltemTemplate 
篇 罚 模 板 


图 10.12 “Menu 任务 ”列表 图 10. 13 “菜单 项 编辑 器 ”对 话 框 
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2. 通过 DataSourcelD 属性 设置 数据 源 控件 

在 网 页 中 拖 放 一 个 Menu 控件 后 ,再 从 工具 箱 的 “数据 ?选项 卡 中 将 SiteMapDataSource 
控件 拖 放 到 网 页 上 ,不 设置 其 任何 属性 ,只 需 将 Menu 控件 的 DataSourceID 设置 为 该 
SiteMapDataSource 控件 的 ID 即 可 ,SiteMapDataSource 控件 会 自动 读 取 站 点 地 图 的 数据 并 
在 Menu 控件 中 显示 。 

或 者 ,在 "Mennu 任务 ”列表 中 单 击 “ 选 择 数 据 源 ” 右 侧 的 @ 按钮 ,在 弹出 的 菜单 中 选择 “新 
建 数 据 源 "命令 ,出 现 “ 数 据 源 配置 向 导 ” 对 话 框 ,选择 “站 点 地 图 ”, 单 击 “ 确 定 ” 按 钮 ,这 样 就 设 
置 了 Menu 控件 的 数据 源 为 Web. sitemap 站 点 地 图 (实际 上 ,系统 自动 创建 一 个 
SiteMapDataSource 控件 ) 。 

3. 通过 编程 方式 添加 菜单 项 

由 于 Menu 控件 的 Items 属性 是 一 个 MenultemCollection 类 对 象 , 因 此 采用 Add 方法 向 
其 中 添加 MenuItem 对 象 。 这 种 方式 可 以 在 运行 时 动态 地 增删 Menu 控件 的 菜单 项 ,下 面 通 
过 一 个 示例 说 明 。 

【 例 10.3】 创建 一 个 WebForm2 网 页 ,采用 编程 方式 通过 Menu 控件 显示 前 面 所 列 的 大 


学 网 站 层次 结构 。 
解 : 其 步骤 如 下 。 


@ 打开 chl0 网 站 ,添加 一 个 代码 隐藏 页 模型 的 网 页 WebForm2. aspx。 
@ 在 该 网 页 的 设计 界面 中 包含 一 个 Menu 控件 Menul 和 一 个 标签 Labell 。 
@ 进入 网 页 的 源 视图 ,添加 Menul 控件 的 相关 属性 如 下 : 


<Levelmenuitemstyles > 
<asp:menuitemstyle BackColor = "LightSteelBlue" ForeColor = "Red" 
BorderStyle = "Outset" Font - Names = "黑体 " Font - Size = "18px" /> 
<asp:menuitemstyle BackColor = "SkyBlue" ForeColor = "Blue" Font - Names = "楷体 " 
Font - Size = "16px"/> 
<asp:menuitemstyle BackColor = "LightSkyBlue" ForeColor = "Black" Font - Names = "仿宋 " 
Font - Size = "14px"/> 
</Levelmenuitemstyles> 
<Levelselectedstyles> 
<asp:menuitemstyle BackColor = "Cyan" ForeColor = "Gray"/> 
<asp:menuitemstyle BackColor = "LightCyan" ForeColor = "Gray"/> 
<asp:menuitemstyle BackColor = "PaleTurquoise" ForeColor = "Gray"/> 
</Levelselectedstyles> 


@ 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
{ if (!Page. IsPostBack) 
{ Menul. Orientation = Orientation. Horizontal; 
Menul. StaticDisplayLevels = 2; // 静 态 显示 两 层 
Menul. Items. Clear(); 
MenuItem node = new MenuItem(" 中 华 大 学 "); 
Menul. Items. Add(node); 
node = new MenuItem(" 院 系 设置 "); 
Menul. Items[0].ChildItems. Add( node); 
node = new MenuItem(" 计 算 机 学 院 "); 
Menul. Items[0].ChildItems[0].ChildItems. Add(node); 


node = new MenuItem(" 电 子 信息 学 院 "); 


Menul. Items[0 


.ChildItems[0].ChildItems. 


node = new MenuItem(" 数 学 学 院 "); 


Menul. Items[0 


.ChildItems[0].ChildItems. 


node = new MenuItem(" 物 理学 院 "); 


Menul. Items[0 


.ChildItems[0].ChildItems. 


node = new MenuItem(" 职 能 部 门 "); 


Menul. Items[0 


.ChildItems. Add( node); 


node = new MenuItem(" 教 务 处 "); 


Menul. Items[0 


.ChildItems[1].ChildItems. 


node = new MenuItem(" 财 务 处 ") ; 


Menul. Items[0 


.ChildItems[1].ChildItenms. 


node = new MenuItem(" 学 生 工 作 处 "); 


Menul. Items[0 


.ChildItems[1].ChildItems. 


node = new MenuItem(" 科 技 处 "); 


Menul. Items[0 
} 
} 


.ChildItems[1].ChildItems. 


protected void Menul MenuItemClick(object sender, 
{ ”Labell.Text = "您 的 选择 是 : <br>"; 
Labell. Text += Menul.SelectedItem. Text; 


} 


Add(node); 


Add(node); 


Add(node); 


Add(node); 


Add(node); 


Add(node); 


Add(node); 


MenuEventArgs e) 
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@ 单 击 工具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 ,将 鼠标 指针 移动 到 “科技 处 ”上 ,其 结 
果 如 图 10. 14 所 示 。 单 击 “ 科 技 处 ”, 其 结果 如 图 10. 15 所 示 。 


|[B rowechorsn1s P - o] 
; 


乱 httpy/ 5916 DO 
x 


图 10.14 WebForm2 网 页 运行 界面 一 


10.5 SiteMapPath 控件 


图 10.15 WebForm2 网 页 运行 界面 二 


SiteMapPath 控件 对 应 System. Web. UI. WebControls 命名 空间 中 的 SiteMapPath 类 。 
该 控件 会 显示 一 个 导航 路 径 ( 也 称 为 当前 位 置 或 页 眉 导 航 ), 此 路 径 为 用 户 显示 当前 网 页 的 位 
置 ,并 显示 返回 到 主页 的 路 径 链接 。 此 控件 提供 了 许多 可 供 自 定义 链接 的 外 观 的 选项 。 

SiteMapPath 控件 的 常用 属性 如 表 10. 13 所 示 。 

SiteMapPath 控件 与 站 点 地 图 密切 相关 , 它 反映 站 点 地 图 对 象 提 供 的 数据 。 如果 将 
SiteMapPath 控件 用 在 未 在 站 点 地 图 中 表示 的 网 页 上 , 则 它 不 会 显示 。 

SiteMapPath 由 结 点 组 成 。 路 径 中 的 每 个 元 素 均 称 为 结 点 ,用 SiteMapNodeItem 对 象 表 
示 。 锚 定 路 径 并 表示 分 层 树 的 根 的 结 点 称 为 根 结 点 ,表示 当前 显示 网 页 的 结 点 称 为 当前 结 点 。 
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当前 结 点 与 根 结 点 之 间 的 任何 其 他 结 点 都 为 父 结 点 。 
表 10.13 SiteMapPath 控件 的 常用 属性 及 其 说 明 


属 性 说 明 

CurrentNodeStyle 定义 当前 结 点 的 样式 ,包括 字体 .颜色 .样式 等 

NodeStyle 定义 导航 路 径 上 所 有 结 点 的 样式 

ParentLevelsDisplayed 指定 在 导航 路 径 上 显示 的 相对 于 当前 结 点 的 父 结 点 层 数 。 默 认 值 为 一 1, 表 
示 父 级 别 数 没有 限制 

PathDirection 指定 导航 路 径 上 各 结 点 的 显示 顺序 。 默 认 值 为 RootToCurrent, 即 按 从 左 到 
右 的 顺序 显示 从 根 结 点 到 当前 结 点 的 路 径 。 另 一 选项 为 CurrentToRoot, 即 
按 相反 的 顺序 显示 导航 路 径 

PathSeparator 指定 导航 路 径 中 结 点 之 间 的 分 隔 符 。 默 认 值 为 "二 ”, 也 可 自 定义 为 其 他 符号 

PathSeparatorStyle 定义 分 隔 符 的 样式 

RenderCurrentNodeAsLink ”是否 将 导航 路 径 上 当前 页 的 名 称 显 示 为 超 链接 。 默 认 值 为 False 

RootNodeStyle 定义 根 结 点 的 样式 

ShowToolTips 当 鼠 标 悬 停 于 导航 路 径 的 某 个 结 点 时 是 否 显示 相应 的 工具 提示 信息 。 默 认 
值 为 True, 即 当 鼠 标 悬 停 于 某 结 点 上 时 显示 该 结 点 在 站 点 地 图 中 定义 的 
Description 属性 值 

SiteMapProvider 获取 或 设置 用 于 呈现 站 点 导航 控件 的 站 点 提供 程序 的 名 称 


SiteMapPath 显示 的 每 个 结 点 都 是 HyperLink 或 Literal 控件 ,开发 人 员 可 以 将 模板 或 样 
式 应 用 到 这 两 种 控件 。 

默认 的 站 点 地 图 名 称 为 Web. sitemap 文件 , 它 是 一 个 XML 文件 。ASP. NET 的 默认 站 
点 地 图 提供 程序 自动 选取 此 站 点 地 图 ,该 文件 必须 位 于 应 用 程序 的 根 目 录 中 。 如 果 是 其 他 名 
称 和 类 型 的 站 点 地 图 ,在 使 用 时 还 必须 为 其 指定 其 他 相 适 应 的 提供 程序 ,可 以 通过 
SiteMapPath 控件 的 SiteMapProvider 属性 来 设置 。 

【 例 10.4】 创建 一 个 WebForm3 网 页 ,说 明 SiteMapPath 控件 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch10 网 站 ,添加 一 个 代码 隐藏 页 模型 的 网 页 WebForm3. aspx。 

@ 在 其 中 放置 一 个 TreeView 控件 TreeView1l 和 一 个 SiteMapSource 控件 SiteMapSourcel 
(自动 加 载 前 面 创建 的 Web. sitemap 站 点 地 图 ) ,将 TreeViewl 控件 的 DataSourceID 属性 设 
置 为 SiteMapSourcel, 并 设置 相应 的 字体 属性 ,如 图 10. 16 所 示 。 

@ 新 建 一 个 schooll. aspx 网 页 ,添加 一 个 HTML 标记 (显示 “您 的 位 置 : ”)、 一 个 
SiteMapPath 控件 SiteMapPathl ,在 下 方 再 添加 一 个 HTML 标记 (显示 “计算 机 学 院 ”) ,并 设 
置 网 页 中 各 控件 和 标记 的 字体 属性 ,如 图 10. 17 所 示 。 

@ 新 建 Web. sitemap 站 点 地 图 中 链接 的 其 他 网 页 ,与 schooll. aspx 网 页 类 似 , 只 是 将 第 
2 个 HTML 标记 的 文字 改 为 相应 的 提示 文字 。 

加 单 击 工 具 栏 中 的 Pp Internet Explorer 按钮 运行 本 网 页 ,出现 如 图 10. 18 所 示 的 运行 界面 , 单 
击 “ 计 算 机 学 院 ”, 自动 转向 schooll. aspx 网 页 .如 图 10. 19 所 示 ,SiteMapPath 控件 自动 显示 
当前 的 位 置 ,可 以 单 击 其 中 的 “中 华 大 学 ”或 “ 院 系 设置 "进行 导航 。 
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EE 日 拆 分 |。 源 | Fd [| [0] <div> 


图 10.16 WebForm3 网 页 设计 界面 图 10.17 schooll. aspx 网 页 设计 界面 


SiteMapPath1 控件 。 PathSeparator 属性 
| 看 | esl 
¢ OO 
您 的 位 置 : 中 华 大 党 》 院 系 设置 》 计 算 机 学 院 
计算 机 学 院 


图 10.18 WebForm3 网 页 运行 界面 图 10. 19 ”schooll. aspx 网 页 运行 界面 


练习 题 10 


1. 简 述 ASP. NET 站 点 导航 的 基本 功能 。 

2. 至 少 列举 3 个 你 见 过 的 使 用 站 点 导航 的 网 站 实例 。 

3. 什么 是 站 点 地 图 ? 简 述 站 点 地 图 的 创建 和 使 用 方法 。 

4. 简 述 TreeView 控件 的 使 用 方法 。 

5. TreeView 控件 中 的 所 有 结 点 构成 一 个 什么 类 对 象 ? 如 何 向 TreeView 控件 中 添加 一 
6. 简 述 Menu 控件 的 使 用 方法 。 

7. 简 述 SiteMapPath 控件 的 使 用 方法 。 
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上 机 实验 题 10 


在 ch10 网 站 中 添加 一 个 名 称 为 Experment10 的 网 页 ,其 中 放置 一 个 TreeView 控件 和 一 
个 iframe 框架 ,采用 手工 方式 添加 TreeView 控件 的 结 点 。 

另外 设计 一 个 dispinfo 网 页 ,其 中 有 一 个 标签 Labell 。 

当 运 行 Experment10 网 页 时 ,用 户 单 击 TreeView 控件 中 的 某 结 点 时 在 iframe 框架 中 显 
示 dispinfo 网 页 ,其 中 的 Labell 标签 显示 用 户 单 击 的 结 点 的 标题 。 10. 20 所 示 的 是 用 户 单 
击 “ 编 辑 学 生 信息 ” 结 点 的 结果 。 


选择 : 编辑 学 生 信息 


图 10.20 上 机 实验 题 10 网 页 的 运行 界面 


ASP.NET AJAX 控件 Eiless 


AJAX( 或 Ajax) 的 英文 全 称 为 “Asynchronous Javascript And XMIL”( 异 步 
JavaScript 和 XML) ,通常 的 读音 为 " 阿 贾 克 斯 ”, 是 指 一 种 创建 交互 式 网 页 应 用 
的 网 页 开发 技术 ,允许 客户 端 通过 异步 HTTP 请 求 与 服务 器 交换 数据 的 技术 ， 
目的 是 利用 已 经 成 熟 的 技术 构建 具有 良好 交互 性 的 Web 应 用 程序 。 本 章 介 绍 
AJAX 技术 和 使 用 ASP.NET AJAX 控件 开发 无 刷新 网 页 的 方法 。 

本 章 学 习 要 点 : 

回 掌握 AJAX 技术 的 原理 。 

回 掌握 各 种 ASP.NET AJAX 控件 的 功能 和 使 用 方法 。 

回 灵 活 使 用 ASP.NET AJAX 控件 开发 无 刷新 网 页 。 


11.1 AJAX 技术 


11.1.1 AJAX 的 工作 原理 


传统 的 Web 应 用 交互 由 用 户 触发 一 个 HTTP 请 求 到 服务 器 ,服务 器 对 其 
进行 处 理 后 再 返回 一 个 新 的 HTHL 页 面 到 客户 端 ,每 当 服务 器 处 理 客 户 端 提 
交 的 请 求 时 ,客户 都 只 能 空闲 等 待 .并 且 哪 怕 只 是 一 次 很 小 的 交互 、 只 需 从 服务 
器 端 得 到 很 简单 的 一 个 数据 ,都 要 返回 一 个 完整 的 HTML 网 页 ,而 用 户 每 次 都 
要 浪费 时 间 和 带宽 去 重新 读 取 整 个 页 面 。 这 个 做 法 浪费 了 许多 带宽 ,由 于 每 次 
应 用 的 交互 都 需要 向 服务 器 发 送 请 求 , 应 用 的 响应 时 间 就 依赖 于 服务 器 的 响应 
时 间 , 这 导致 了 用 户 界 面 的 响应 比 本 地 应 用 慢 得 多 。 

为 此 出 现 了 AJAX 技术 。AJAX 是 一 种 独立 于 Web 服务 器 软件 的 浏览 器 
技术 ,通过 在 后 台 与 服务 器 进行 少量 的 数据 交换 可 以 使 网 页 实现 异步 更 新 。 如 
图 11.1 所 示 , 传 统 的 网 页 (不 使 用 AJAX) 如 果 需 要 网 页 更 新 内 容 , 必 须 重 载 整 
个 页 面 ,而 使 用 AJAX 的 网 页 可 以 在 不 重新 加 载 整个 网 页 的 情况 下 对 网 页 的 某 
部 分 进行 更 新 ,通常 称 AJAX 页 面 为 无 刷新 Web 页 面 。 

所 以 ,AJAX 不 是 一 种 新 的 编程 语言 ,而 是 一 种 用 于 创建 更 好 、 更 快 以 及 交 
互 性 更 强 的 Web 应 用 程序 的 技术 。 这 种 技术 在 浏览 器 与 Web 服务 器 之 间 使 用 
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异步 数据 传输 (HTTP 请 求 ) ,这 样 就 可 使 网 页 从 服务 器 请 求 少 量 的 信息 ,而 不 是 整个 页 面 ,从 
而 使 因特网 应 用 程序 更 小 、 更 快 、 更 友好 。 

AJAX 的 工作 原理 如 图 11. 2 所 示 , 相 当 于 在 用 户 和 服务 器 之 间 加 了 一 个 中 间 层 (AJAX 
引擎 ) ,使 用 户 操作 与 服务 器 响应 异步 化 。 并 不 是 所 有 的 用 户 请 求 都 提交 给 服务 器 , 像 一 些 数 
据 验证 和 数据 处 理 等 都 交 给 AJAX 引擎 自己 来 做 ,只 有 确定 需要 从 服务 器 读 取 新 数据 时 再 由 
AJAX 引擎 代为 向 服务 器 提交 请 求 。 


用 户 界 面 
传统 页 面 请 求 f 客 
攻 四 oe HTML+CSS | 咏 
| 
客户 端 全 | 完整 页 面 响应 服务 器 AJAX 引 擎 
ESSsS 了 
(a) 传统 页 面 处 理 过 程 HTTP 请 求 。 XML 数据 
T 
AJAX 页 面 请 求 Web 和 XML 服务 器 
BS a 局 
一 一 | 各 
ED 部 分 页 面 响应 
客户 路 服务 器 数据 处 理 | 可 
(b) AJAX 页 面 处 理 过 程 
图 11.1 传统 页 面 和 AJAX 页 面 的 处 理 过 程 图 11.2 AJAX 工作 原理 


11.1.2 XmlHttpRequest 对 和 象 


AJAX 的 核心 是 JavaScript 的 XmlHttpRequest 对 象 。 该 对 象 在 IE5 中 首次 引入 , 它 是 一 
种 支持 异步 请 求 的 技术 。 简 而 言 之 .XmlHttpRequest 使 开发 人 员 可 以 使 用 JavaScript 向 服务 
器 提出 请 求 并 处 理 响应 ,而 不 阻塞 用 户 。 

XmlHttpRequest 对 象 的 创建 十 分 简单 。 例 如 ,以 下 代码 用 于 在 IE7 及 更 高 版 本 中 创建 
一 个 XmlHttpRequest 对 象 xmlHttp: 

< script type = "text/javascript"> 

var xmlHttp = new XMLHttpRequest() 7 

</script> 

所 有 现代 浏览 器 (IE7 和 更 高 版 本 、Firefox、Chrome、Safari 以 及 Opera) 均 内 建 
XMLHttpRequest 对 象 ,而 老 版 本 的 IE5 和 IE6 使 用 ActiveX 对 象 : 


var xmlHttp = new ActiveXObject("Microsoft. XMLHTTP" ); 


为 了 应 对 所 有 的 现代 浏览 器 ,包括 IE5 和 IE6, 需 要 检查 浏览 器 是 否 支持 XMLHttpRequest 
对 象 。 如 果 支 持 , 则 创建 XMLHttpRequest 对 象 ; 如 果 不 支 持 , 则 创建 ActiveXObject, 完 整 的 
代码 如 下 : 


var xmlhttp; 

if (window. XMLHttpRequest) 

{ ”// 用 于 IE7 和 更 高 版 本 、Firefox、Chrome、Opera、Safari 
xmlhttp = new XMLHttpRequest(); 

} 


else 
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{ // 用 于 IE6、IE5 
xmlhttp = new RctiveXObject("Microsoft. XMLHTTP" ) ; 


} 


1. XmlHttpRequest 对 象 的 属性 


XmlHttpRequest 对 象 的 属性 如 表 11. 1 所 示 。 其 中 ,readyState 属性 的 5 个 状态 中 每 个 


都 有 一 个 相关 联 的 非 正 式 的 名 称 , 表 11. 2 给 出 了 各 状态 的 状态 值 `. 名 称 和 说 明 。 


属 性 


表 11.1 XmlHttpRequest 对 象 的 属性 
说 明 


readyState 


responseText 


response XML. 


status 


statusText 


HTTP 请 求 的 状态 。 当 一 个 XMLHttpRequest 初次 创建 时 ,这 个 属性 的 值 从 0 开始 ,直到 
接收 到 完整 的 HTTP 响应 ,这 个 值 增加 到 4。readyState 的 值 不 会 递减 ,除非 当 一 个 请 求 
在 处 理 过 程 中 调用 了 abort( ) 或 open() 方 法 。 每 次 这 个 属性 的 值 增加 的 时 候 都 会 触发 
onreadystatechange 事件 句柄 

服务 器 接收 到 的 响应 体 ( 不 包括 头 部 ) ,或 者 如 果 还 没有 接收 到 数据 ,就 是 空 字符 串 。 如 果 
readyState 小 于 3, 这 个 属性 就 是 一 个 空 字符 串 ; 如 果 readyState 为 3, 这 个 属性 返回 目前 
已 经 接收 的 响应 部 分 ; 如 果 readyState 为 4, 这 个 属性 保存 了 完整 的 响应 体 。 如 果 响 应 包 
含 了 为 响应 体 指定 字符 编码 的 头 部 ,就 使 用 该 编码 ,否则 假定 使 用 UTF-8 

对 请 求 的 响应 ,解析 为 XML 并 作为 Document 对 象 返回 

由 服务 器 返回 的 HTTP 状态 代码 ,如 200 表示 成 功 ,而 404 表示 没有 发 现 错误 。 当 
readyState 小 于 3 的 时 候 读 取 这 一 属性 会 导致 一 个 异常 

该 属性 用 名 称 而 不 是 数字 指定 了 请 求 的 HTTP 的 状态 代码 。 也 就 是 说 , 当 状态 为 200 的 
时 候 它 是 “OK”, 当 状 态 为 404 的 时 候 它 是 “Not Found”。 和 status 属性 一 样 , 当 
readyState 小 于 3 的 时 候 读 取 这 一 属性 会 导致 一 个 异常 


表 11.2 readyState 属性 的 状态 值 .名 称 和 说 明 


状态 名 称 描述 
0 Uninitialized 初始 化 状态 。XMLHttpRequest 对 象 已 创建 或 已 被 abort() 方 法 重 置 
1 Open open( ) 方 法 已 调用 ,但 是 send() 方 法 未 调用 ,请 求 还 没有 被 发 送 
2 Sent Send() 方 法 已 调用 ,HTTP 请 求 已 发 送 到 Web 服务 器 ,未 接收 到 响应 
和 Receiving 所 有 响应 头 部 都 已 经 接收 到 ,响应 体 开始 接收 但 未 完成 
4 Loaded HTTP 响应 已 经 完全 接收 


2. XmlHttpRequest 对 象 的 事件 句柄 


onreadystatechange 是 XmlHttpRequest 对 象 的 事件 句柄 ,每 次 readyState 属性 改变 的 时 


候 调用 该 事件 句柄 设置 的 事件 句柄 函数 。 当 readyState 为 3 时 , 它 也 可 能 调用 多 次 。 
3. XmlHttpRequest 对 象 的 方法 
XmlHttpRequest 对 象 的 方法 如 表 11. 3 所 示 ,下 面 介绍 几 个 主要 方法 的 使 用 。 


表 11.3 XmlHttpRequest 对 象 的 方法 


法 说 明 


abort 


取消 当前 响应 ,关闭 连接 并 且 结 束 任何 未 决 的 网 络 活动 。 该 方法 把 
XMLHttpRequest 对 象 重 置 为 readyState 为 0 的 状态 ,并 且 取消 所 有 未 决 的 网 络 活 
动 。 例 如 ,如 果 请 求 用 了 太 长 时 间 , 而 且 响应 不 再 必要 的 时 候 , 可 以 调用 这 个 方法 


getAllResponseHeaders 把 HTTP 响应 头 部 作为 未 解析 的 字符 串 返 回 。 如 果 readyState 小 于 3 ,这 个 方法 


返回 null, 和 否则 它 返 回 服务 器 发 送 的 所 有 HTTP 响应 的 头 部 。 头 部 作为 单个 的 
字符 串 返 回 ,一 行 一 个 头 部 。 每 行 用 换行 符 “\r\n” 隔 开 
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续 表 
方 ”法 说 明 
getResponseHeader 该 方法 的 返回 值 是 指定 的 HTTP 响应 头 部 的 值 ,如 果 没 有 接收 到 这 个 头 部 或 者 
readyState 小 于 3, 则 为 空 字符 串 ; 如 果 接 收 到 多 个 有 指定 名 称 的 头 部 ,这 个 头 部 
的 值 被 连接 起 来 并 返回 ,使 用 逗号 和 空格 分 隔 开 各 个 头 部 的 值 


open 初始 化 HTTP 请 求 参 数 , 例 如 URL 和 HTTP 方法 ,但 是 并 不 发 送 请 求 
send 发 送 HTTP 请 求 ,使 用 传递 给 open 方法 的 参数 以 及 传递 给 该 方法 的 可 选 请 求 体 
setRequestHeader 向 一 个 打开 但 未 发 送 的 请 求 设置 或 添加 一 个 HTTP 请 求 


(1) XMLHttpRequest. open() 方 法 

该 方法 的 语法 格式 如 下 : 

open( method, url, async, username, password) 

其 中 ,各 参数 的 说 明 如 下 。 

。 method: 用 于 请 求 的 HTTP 方 法 ,可 以 是 GET、POST 或 HEAD。 

。 url 参数 是 请 求 的 主体 。 大 多 数 浏览 器 实施 了 一 个 同 源 安全 策略 ,并 且 要 求 这 个 URL 
与 包含 脚本 的 文本 具有 相同 的 主机 名 和 端口 。 

。 async: 指示 请 求 使 用 应 该 异步 地 执行 。 如 果 这 个 参数 是 False ,请求 是 同步 的 ,后 续 对 
send() 的 调用 将 阻塞 ,直到 响应 完全 接收 ; 如 果 这 个 参数 是 True 或 省 略 ,请求 是 异步 
的 , 且 通 常 需要 一 个 onreadystatechange 事件 句柄 。 

。 username 和 password: 可 选 的 ,为 url 所 需 的 授权 提供 认证 资格 。 如 果 指 定 了 ,它们 
会 覆盖 url 自己 指定 的 任何 资格 。 

(2) XMLHttpRequest. send() 方 法 

该 方法 的 语法 格式 如 下 : 

send( body) 


如 果 通 过 调用 open() 指 定 的 HTTP 方法 是 POST 或 PUT,body 参数 指定 了 请 求 体 , 作 
为 一 个 字符 串 或 者 Document 对 象 。 对 于 任何 其 他 方法 ,这 个 参数 是 不 可 用 的 ,应 该 为 null。 

这 个 方法 导致 一 个 HTTP 请 求 发 送 。 如 果 之 前 没有 调用 open(), 或 者 更 具体 地 说 ,如 果 
readyState 不 是 1,send() 抛 出 一 个 异常 ,否则 它 发 送 一 个 HTTP 请 求 。 


11.1.3 实现 AJAX 的 步骤 


AJAX 的 工作 流程 中 涉及 多 个 对 象 .每 个 对 象 完成 不 同 的 功能 。 多 个 对 象 协作 工作 的 整 
体 构成 了 AJAX。 实 现 AJAX 的 基本 步骤 如 下 : 

Oa 创建 XMLHttpRequest 对 象 。 

@ 创建 一 个 HTTP 请 求 。HTTP 请 求 一 般 包括 服务 器 的 地 址 、 请 求 的 文件 和 传送 的 参 
数 等 ,让 XMLHttpRequest 对 象 知道 从 何 处 加 载 数 据 ,其 机 制 与 以 前 介绍 的 HTTP 请 求 一 
样 。 调 用 XMLHttpRequest 对 象 的 open 方法 即 可 设置 HTTP 请 求 和 请 求 的 方式 。 

@ 设置 相应 HTTP 请 求 的 事件 句柄 函数 。 在 向 服务 器 发 送 请 求 后 ,因为 是 异步 请 求 , 服 
务 器 不 一 定 马上 就 发 出 响应 , Web 浏览 器 也 不 会 等 待 服务 器 的 响应 。 但 浏览 器 需要 在 数据 加 

完毕 时 得 到 通知 ,达到 这 个 目的 的 通用 方法 是 给 XMLHttpRequest 对 象 设 置 事件 句柄 函数 

(回调 函数 ) ,XMLHttpRequest 对 象 根据 自身 的 状态 变化 调用 相应 的 函数 。 
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@ 发 送 HTTP 请 求 。 调 用 XMLHttpRequest 对 象 的 send 方法 即 可 发 送 HTTP 请 求 。 

@ 等 待 响应 。 

@ 使 用 DOM( 文 档 对 象 模型 ) 实 现 局 部 刷新 , 即 给 当前 网 页 的 表单 域 赋值 。 

为 了 能 够 响应 HTTP 请 求 , 服 务 器 应 有 相应 的 处 理 程序 ,这 种 处 理 程序 设计 有 多 种 方法 。 
在 ASP.NET 中 可 以 创建 自 定义 的 HTTP 处 理 程序 ,下 面 介绍 HTTP 处 理 程序 的 概念 和 创 
建 自 定义 HTTP 处 理 程序 的 方法 。 


11.1.4 HTTP 处 理 程 序 


ASP.NET HTTP 处 理 程序 是 响应 对 ASP.NET Web 应 用 程序 的 请 求 而 运行 的 过 程 。 
最 常用 的 处 理 程序 是 处 理 . aspx 文件 的 ASP.NET 网 页 处 理 程序 。 当 用 户 请 求 . aspx 网 页 文 
件 时 ,ASP.NET 通过 网 页 处 理 程序 来 处 理 请 求 。 

实际 上 , ASP . NET 根据 文件 扩展 名 将 HTTP 请 求 映 射 到 HTTP 处 理 程序 。 每 个 
HTTP 处 理 程序 都 可 以 处 理应 用 程序 中 的 单个 HTTP URL 或 URL 扩展 名 组 。ASP. NET 
包括 几 种 内 置 的 HTTP 处 理 程 序 , 如 表 11.4 所 示 。 


表 11.4 ASP.NET 的 几 种 内 置 的 HTTP 处 理 程序 


处 理 程序 说 明 
ASP. NET 网 页 处 理 程序 (* .aspx) ”用 于 所 有 ASP.NET 网 页 的 默认 HTTP 处 理 程序 
Web 服务 处 理 程序 ( x* . asmx) 在 ASP.NET 中 作为 . asmx 文件 创建 的 Web 服务 的 默认 HTTP 处 
理 程序 
一 般 Web 处 理 程序 (* . ashx) 不 含 用 户 界面 和 包括 @WebHandler 指令 的 所 有 Web 处 理 程序 的 默 
认 HTTP 处 理 程序 
跟踪 处 理 程序 (trace. axd) 显示 当前 网 页 跟踪 信息 的 处 理 程序 


迄今 为 止 ,所 有 的 网 页 请 求 都 使 用 ASP.NET 默认 HTTP 处 理 程序 。 实 际 上 ,开发 人 员 
可 以 创建 自 定义 HTTP 处 理 程序 。 
若 要 创建 自 定义 HTTP 处 理 程序 ,需要 创建 实现 IHttpHandler 接口 的 类 来 创建 一 个 同 
步 处 理 程序 ,或 者 可 以 实现 IHttpAsyncHandler 来 创建 一 个 异步 处 理 程序 。 两 种 处 理 程序 接 
口 都 要 求实 现 ISReusable 属性 和 ProcessRequest 方法 。 
以 创建 同步 处 理 程序 为 例 , 使 用 的 IHttpHandler 是 一 个 .NET Framework 接口 , 它 定 义 
ASP. NET 为 使 用 自 定义 HTTP 处 理 程 序 同 步 处 理 HTTP Web 请 求 而 实现 的 协定 。 
IHttpHandler 接口 有 以 下 属性 和 方法 。 
。 IsReusable: 它 是 一 个 实现 ,用 于 获取 一 个 值 , 该 值 指示 其 他 请 求 是 否 可 以 使 用 
IHttpHandler 实例 。 

。 ProcessRequest: 它 是 一 个 方法 ,负责 处 理 单个 HTTP 请 求 , 在 此 方法 中 将 编写 生成 
处 理 程序 输出 的 代码 。 通 过 实现 IHttpHandler 接口 的 自 定义 HttpHandler 启用 
HTTP Web 请 求 的 处 理 。 

用 户 可 以 用 任何 符合 公共 语言 规范 (CLS) 的 语言 编写 自 定 义 HTTP 处 理 程序 来 处 理 特 
定 的 、 预 定义 类 型 的 HTTP 请 求 。 响 应 这 些 特定 请 求 的 是 在 HttpHandler 类 中 定义 的 可 执行 
代码 ,而 不 是 常规 的 ASP 或 ASP.NET 网 页 。 
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11.1.5 AJAX 编程 示例 


【 例 11.1】 在 DD 盘 ASP.NET 目录 中 建立 一 个 chll 的 子 目 录 , 将 其 作为 网 站 目录 ,然后 
创建 一 个 WebForml 网 页 和 一 般 处 理 程序 AddHandler. ashx, 其 功能 是 采用 AJAX 技术 实现 


两 个 整数 相 加 的 运算 。 
解 : 其 步骤 如 下 。 
@ 启动 Visual Studio 2012 。 


@ 选择 "文件 | 新 建 | 网 站 ?命令 ,出 现 * 新 建 网 站 ”对话 框 ,然后 选择 “ASP.NET 空 网 站 ” 


模板 ,选择 “Web 位 置 "为 文件 系统 ”, 单 击 “ 浏 览 ” 按 钮 ,选择 “D:\ASP.NET\ch11” 目 录 , 单 击 


“确定 ”按钮 ,创建 一 个 空 的 网 站 ch11。 


@ 选择 “网 站 | 添加 新 项 ”命令 ,创建 一 个 单 文件 页 模型 的 WebForml. aspx 网 页 ,其 设计 
界面 如 图 11. 3 所 示 , 其 中 的 控件 采用 HTML 标记 实现 (都 是 客户 端 控件 )。 对 应 的 源 视 图 代 


码 如 下 : 


<% @Page Language = "C#" %> 

<!DOCTYPE html > 

< script type = "text/javascript"> 
Var xmlHttp; 
function createXMLHttpRequest() 
{ 


xmlHttp = new XMLHttpRequest(); // 创 建 一 个 XmlHttpRequeset 对 象 
} 
function AddNumber( ) // 事 件 处 理 函 数 
{ createXMLHttpRequest(); // 创 建 一 个 XmlHttpRequeset 对 象 


var url= "RddHandler. ashx?numl = ”+ document.getElementById("num1").value 
+ "&num2 = " + document.getElementById("num2" ).value; 


xmlHttp. open("GET", url, true); // 创 建 一 个 HTTP 请 求 
xmlHttp. onreadystatechange = ShowResult; // 设 置 事件 句柄 函数 
xmlHttp. send(nul1) // 发 送 请 求 


} 
function ShowResult() 


{ if(xmlHttp.readyState == 4) // 正 常 响应 状态 
{ if(xmlHttp.status==200) // 正 确 接受 响应 数据 
document. getElementById(" sum" ) . value = xmlHttp. responseText; 
// 局 部 刷新 
} 
} 
</script> 


<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head runat = "server"> 
<meta http - equiv= "Content - Type" content = "text/html; charset = utf— 8"/> 
<title></title> 
<style type = "text/css"> 
.auto— stylel { 
font - family: 隶书 ; font - weight: bold; 
font - size: large; color: 井 EFF0000; 
.auto— style2 { font ~ family: Arial; font ~ size: small; } 
</style> 
</head> 
<body> 
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<form id= "forml" runat = "server"> 
<div> 
< span class = "auto - stylel"> AJAX 编程 </span> 


<br /> 
<p style = "color: 井 0000FF; font - size: medium; font — weight: 700; 


font - family: 楷体 "> 数 1: 
< input type = "text" id= "numl" size= "10" onkeyup = "AddNumber()" 


value = "0" class = "auto— style2" /> 


Snbsp;&nbsp; 数 2: 
< input type = "text" id= "num2" size= "10" onkeyup = "AddNumber()" 
value = "0" class = "auto - style2" /> 
相 加 结果 : 
< input type = "text" id= "sum" size= "10" aria- readonly = "True" 
class = "auto - style2" /> 
</p> 
</div> 
</form> 
</body> 
</html > 
由 于 WebForml. aspx 网 页 中 创建 了 XmlHttpRequeset 对 象 , 所 以 它 是 一 个 AJAX 网 页 。 


|AJAX 旺 程 


| 


;ee 
[en 拆 分 |。 源 | [4][<html>][<body>|[<formsforml>] <p> 四 
图 11.3 WebForml 网 页 设计 界面 

@ 选择 “网 站 | 添加 新 项 "命令 ,出 现 “ 添 加 新 项 -ch11” 对 话 框 ,在 中 间 列 表 中 选择 “一 般 处 
理 程序 ”模板 ,修改 文件 名 为 AddHandler. ashx, 如 图 11.4 所 示 , 单 击 “ 添 加 ”按钮 。 


AddHandler.ashx 


图 11.4 “添加 新 项 -ch11” 对 话 框 
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此 时 直接 进入 代码 编辑 窗口 ,输入 以 下 粗 体 部 分 的 代码 : 


<% @WebHandler Language = "C 井 " Class = "AddHandler" %> 
using System; 
using System. Web; 
public class AddHandler: IHttpHandler 
{ public void ProcessRequest(HttpContext context) 
{ context.Response.ContentType = "text/plain" 
int a = Convert.ToInt32(context.Request.QueryString["num1" ]); 
int b = Convert.ToInt32(context.Request.QueryString["num2" ]); 
int result = a + b; 
context. Response. Write(result); 
} 
public bool IsReusable 
{ get 
{ 
return false; // 指 示 其 他 请 求 不 能 使 用 IHttpHandler 实例 
} 


} 


其 中 , AddHandler. ashx 是 自 定义 的 HTTP 处 理 程序 ,通过 对 IHttpHandler 接口 的 
ProcessRequest 方法 实现 来 响应 WebForml. aspx 网 页 的 请 求 。 

@ 单 击 工具 栏 中 的 Internet Explorer 按钮 运行 WebForml 网 页 ,只 要 在 前 两 个 文本 框 中 输 
入 数值 ,第 3 个 文本 框 中 会 立即 显示 相 加 的 结果 ,例如 输入 10 和 20 的 结果 如 图 11. 5 所 示 。 
由 于 没有 显 式 提交 ,所 有 的 运行 看 起 来 都 是 在 客户 端 进行 的 ,实际 上 客户 端 通过 异步 HTTP 
请 求 与 服务 器 交换 数据 ,这 可 以 看 成 是 无 刷新 的 自动 计算 。 
| [EB wpwocalhose6lq73webFomlaspx 
@ localhost x 
AJAX48 程 


数 1: |10 


图 11.5 WebForml 网 页 运行 界面 
11.2 ASP.NET AJAX 


前 面 介 绍 了 采用 客户 端 编程 实现 AJAX 的 方法 ,其 过 程 十 分 复杂 ,实际 上 ,ASP.NET 提 
供 了 一 组 AJAX 控件 以 便于 开发 人 员 进 行 AJAX 网 页 设计 。 所 谓 ASP .NET AJAX 就 是 
AJAX 的 Microsoft 实现 方式 ,对 AJAX 的 使 用 以 控件 形式 提供 。 


11.2.1 ASP.NET AJAX 概述 


在 Visual Studio 2010 之 前 ,ASP.NET AJAX 是 一 个 独立 安装 的 产品 ,必须 安装 在 客户 
端 和 Web 服务 器 上 。 在 Visual Studio 2010 及 之 后 的 版 本 中 , ASP .NET AJAX 不 仅 是 
Visual Studio 的 一 部 分 ,还 内 置 到 .NET Framework 中 。 也 就 是 说 ,使 用 ASP.NET 4.5 时 应 
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用 ASP.NET AJAX 不 需要 任何 额外 的 安装 。 
Visual Studio 2012 提供 的 ASP .NET AJAX 位 于 工具 箱 的 “AJAX 扩展 ”类 别 中 ,如 

11.6 所 示 。 所 有 AJAX 控件 都 是 服务 器 控件 。 
ASP.NET AJAX 的 命名 空间 为 System. Web. UI, 对 


[NAxi 民 | 
应 的 程序 集 是 System. Web. Extensions( 在 System. Web. * 指针 
晤 scriptManager 
Extensions. dll 中 ) 。 国 ScriptManagerProxy 
ASP.NET AJAX 控件 可 以 像 其 他 服务 器 控件 一 样 被 pare 
拖 放 到 网 页 中 ,包含 有 ASP.NET AJAX 控件 的 网 页 称 为 加 Updateprogress 


AJAX 网 页 。 每 个 AJAX 网 页 都 需要 使 用 一 个 
ScriptManager 控件 ,只 要 在 网 页 上 使 用 这 个 控件 ,就 启动 
了 ASP.NET 的 AJAX 功能 。 


11.2.2 ScriptManager 控件 


ScriptManager 控件 用 于 管理 一 个 网 页 上 的 所 有 AJAX 资源 , 它 是 AJAX 功能 的 核心 ,为 
需要 部 分 更 新 的 网 页 提供 支持 AJAX 的 服务 器 。 每 个 ASP .NET 网 页 都 需要 一 个 
ScriptManager 控件 来 工作 ,在 一 个 网 页 上 只 能 有 一 个 ScriptManager 控件 。 

ScriptManager 控件 比较 重要 的 属性 如 下 。 

。 Scripts 属性 : 获取 一 个 包含 ScriptReference 对 象 (每 个 对 象 代表 一 个 呈现 给 客户 端的 
脚本 文件 ) 的 ScriptReferenceCollection 对 象 。 
Services 属性 : 获取 一 个 ServiceReferenceCollection 对 象 ,该 对 象 包含 ASP.NET 在 
客户 端 上 针对 AJAX 功能 公开 的 每 个 Web 服务 的 ServiceReference 对 象 。 
。 SupportsPartialRendering 属性 : 获取 一 个 指示 客户 端 是 否 支持 部 分 页 面 呈 现 的 值 。 
。 EnablePartialRendering 属性 : 获取 或 设置 一 个 可 部 分 呈现 页 面 的 值 , 以 便 使 用 
UpdatePanel 控件 来 单独 更 新 页 面 区 域 。 

在 编写 客户 端的 JavaScript 代码 时 ,可 以 将 其 放置 在 网 页 的 二 script 二 元 素 中 ,也 可 以 将 
JavaScript 代码 单独 放 在 一 个 .js 文件 (静态 脚本 文件 ) 中 。 如 果 采 用 后 者 ,需要 在 网 页 中 引 
用 .js 文件 ,通过 将 asp: ScriptReference 元 素 添加 到 网 页 上 asp: ScriptManager 元 素 内 的 
Scripts 结 点 中 来 引用 .js 文件 。 例 如 ,以 下 代码 用 于 引用 myscript. js 文件 : 

<asp:ScriptManager ID = "SM1" runat = "server"> 

<Scripts > 
<asp:ScriptReference Name = "myscript. js" /> 
</Scripts> 

</asp:ScriptManager > 

其 中 二 asp:ScriptReference Name 一 "myscript. js”" /全 就 是 一 个 定义 的 ScriptReference 
对 象 ,这 样 在 网 页 中 就 可 以 调用 myscript. js 文件 中 的 JavaScript 函数 。 

从 上 面 可 以 看 到 ,ScriptReference 类 的 功能 用 于 注册 JavaScript 脚本 文件 ,将 其 包括 在 
ASP.NET 网 页 上 ,以 便 在 网 页 上 的 客户 端 中 使 用 它 的 功能 。ScriptReference 类 有 以 下 属性 。 

。 Name 属性 : 获取 或 设置 包含 客户 端 脚本 文件 的 嵌入 资源 的 名 称 。 

。 Path 属性 : 获取 或 设置 引用 客户 端 脚 本 文件 相对 于 网 页 的 路 径 。 

。 ScriptMode 属性 : 获取 或 设置 要 使 用 的 客户 端 脚 本 文件 的 版 本 (发 布 版 本 或 调试 

版 本 ) 。 


图 11.6 ASP.NET AJAX 控件 
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用 户 还 可 以 通过 使 用 ScriptReferenceCollection 类 的 Add 方法 以 编程 方式 将 ScriptReference 
对 象 添加 到 Scripts 集合 中 。 

Services 属性 用 于 引用 Web 服务 ,与 Scripts 属性 的 使 用 方式 类 似 , 有 关 Web 服务 的 设计 
将 在 第 14 章 介 绍 。 

为 了 支持 部 分 页 面 呈 现 , ASP.NET 网 页 必须 满足 以 下 条 件 : 

。 ScriptManager 控件 的 EnablePartialRendering 属性 必须 为 True( 默 认 值 ) 。 

。 网 页 上 必须 至 少 有 一 个 UpdatePanel 控件 。 

。 SupportsPartialRendering 属性 必须 为 True( 默 认 值 )。 如 果 没 有 显 式 设 置 Supports- 

PartialRendering 属性 , 则 其 值 依 浏览 器 功能 而 定 。 

当 部 分 网 页 呈现 受到 支持 时 ,ScriptManager 控件 会 呈现 脚本 以 启用 异步 回 发 和 部 分 网 
页 更 新 ,可 使 用 UpdatePanel 控件 来 指定 要 更 新 的 网 页 区 域 。ScriptManager 控件 会 处 理 异步 
回 送 ,并 且 只 刷新 必须 要 更 新 的 网 页 区 域 。 


11.2.3 UpdatiePanel 控件 


UpdatePanel 控件 是 一 个 容器 控件 ,放置 在 其 中 的 控件 具有 在 没有 回 传 时 允许 局 部 刷新 
的 功能 。 也 就 是 说 ,UpdatePanel 控件 允许 定义 网 页 的 某 些 区 域 支 持 使 用 ScriptManager, 之 
后 这 些 区 域 就 可 以 回 送 部 分 页 面 , 在 正常 的 ASP.NET 页 面 回 送 过 程 之 外 更 新 它们 自己 。 

1. ContentTemplate 属性 

该 属性 是 UpdatePanel 控件 最 重要 的 属性 ,用 于 获取 或 设置 定义 UpdatePanel 控件 内 容 
的 模板 。 也 就 是 说 , UpdatePanel 控件 作为 容器 包含 的 所 有 需要 局 部 刷新 的 控件 都 包含 在 
ContentTemplate 属性 中 。 

默认 情况 下 ,包含 在 UpdatePanel 控件 的 ContentTemplate 属性 中 的 任何 回 送 控件 (例如 
命令 按钮 单 选 按钮 .列表 框 等 ) 都 将 导致 异步 回 送 并 刷新 部 分 页 面 内 容 。 

【 例 11.2】 创建 一 个 AJAX 网 页 WebForm2 ,其 功能 是 说 明 UpdatePanel 控件 的 应 用 。 

解 : 其 步骤 如 下 。 

@ 打开 chll 网 站 ,添加 一 个 代码 隐藏 页 模型 的 网 页 WebForm2. aspx。 

@ 其 设计 界面 如 图 11.7 所 示 , 其 中 包含 一 个 ScriptManagerl 控件 和 一 个 UpdatePanell 
控件 ,UpdatePanell 控件 中 包含 一 个 HTML 标签 ,一 个 只 读 文 本 框 TextBoxl 和 一 个 命令 按 
钮 Button1。UpdatePanell 控件 的 源 视图 代码 如 下 : 

<asp:UpdatePanel ID= "UpdatePanell" runat = "server"> 

<ContentTemplate> 
< span class = "auto - stylel"> 单 击 时 刻 : </span > 
<asp:TextBox ID = "TextBoxl”runat = "server" ReadOnly = "True" 
style = "font - size: small; font ~ family: Arial" Width = "122px"></asp:TextBox> 
<br /><br /> 
<asp:Button ID= "Button1l" runat = "server" OnClick = "Buttonl_Click" 
style = "color: 井 FF0000; font— size: medium; font — weight: 700; 
font - family: 黑体 "Text = " 单 击 " /> 
</ContentTemplate > 

</asp:UpdatePanel > 

从 中 看 到 UpdatePanell 控件 的 ContentTemplate 属性 是 一 个 列表 ,包含 了 所 放置 的 标准 
控件 TextBoxl 和 Buttonl 。 
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@ 在 Buttonl 上 设计 如 下 事件 处 理 过 程 : 


protected void Button1_Click(object sender, EventArgs e) 
{ 
TextBox1l.Text = DateTime. Now. ToString(); 


} 

@ 单 击 工具 栏 中 的 p Inmternet Explorer 按钮 运行 本 网 页 ,然后 单 击 “ 单 击 ”命令 按钮 ,其 结果 如 
图 11.8 所 示 。 这 看 起 来 与 普通 网 页 没有 什么 区 别 , 但 实际 上 每 次 单 击 时 都 会 引发 异步 回 送 ， 
改变 显示 的 时 间 。 


(HE @ hapyWlocalhost5147 DP - 
@ localhost x 


章 击 时 刻 : [2015/427 9-09-31 


4 » 
设计 | 日 拆 分 |。 源 | [4] <aspiTextBoxs 


图 11.7 WebForm2 网 页 设计 界面 图 11.8 WebForm2 网 页 运行 界面 


上 述 网 页 运行 时 客户 端的 部 分 源 代码 如 下 : 
<div id= "UpdatePanel1"> 
<span class = "auto- stylel"> 单 击 时 刻 : </span> 
< input name = "TextBox1" type = "text" readonly = "readonly" id = "TextBox1" 
style= "width:122px; font - size: small; font- family: Arial" /> 
<br /><br /> 
< input type = "submit" name = "Buttonl"” value = " 单 击 " id= "Button1" 
style= "color: #FF0000; font— size: medium; font— weight: 700; font - family: 黑体 " /> 
</span> 
如 果 不 使 用 ScriptManagerl 控件 和 UpdatePanell 控件 ,其 他 相同 ,对 应 的 客户 端的 部 分 
源 代码 如 下 : 
<span class = "auto- stylel"> 单 击 时 刻 : </span> 
< input name = "TextBox1" type = "text" value = "2015/4/27 9:29:25" readonly = "readonly" 
id = "TextBoxl”style = "width:122px;font - size: small; font ~ family: Arial" /> 
<br /><br /> 
< input type = "submit" name = "Button1" value = " 单 击 " id= "Button1" 
style= "color: ##FF0000; font— size: medium; font— weight: 700; font - family: 黑体 " /> 
对 比 两 者 ,可 以 看 出 AJAX 网 页 与 普通 网 页 的 不 同 。 即 用 户 单 击 时 AJAX 网 页 在 客户 端 
运行 并 提取 客户 机 的 时 间 , 而 非 AJAX 网 页 回 传 到 服务 器 ,提取 服务 器 的 时 间 并 回 发 给 客 
户 端 。 
2. ChildrenAsTriggers 属性 
该 属性 获取 或 设置 一 个 值 , 该 值 指示 来 自 UpdatePanel 控件 的 直接 子 控件 的 回 发 是 否 更 
新 该 面板 的 内 容 。 
如 果 和 希望 来 自 UpdatePanel 控件 的 直接 子 控件 的 回 发 更 新 面板 内 容 , 则 将 ChildrenAsTiiggers 
属性 设置 为 True。 垦 套 的 UpdatePanel 控件 的 子 控件 不 会 更 新 父 UpdatePanel 控件 的 内 容 ， 
除非 显 式 调用 Update 方法 或 者 将 这 些 子 控件 定义 为 触发 器 。 
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3. UpdateMode 属性 

该 属性 获取 或 设置 一 个 值 , 该 值 指示 何 时 更 新 UpdatePanel 控件 的 内 容 , 可 以 取 值 
Always( 默 认 值 ) 或 Conditional 。 

取 值 为 Always 表示 源 于 页 面 的 所 有 回 发 ,UpdatePanel 控件 的 内 容 都 会 进行 更 新 ,其 中 
也 包括 异步 回 发 ; 取 值 为 Conditional 表示 UpdatePanel 控件 的 内 容 在 有 条 件 时 进行 更 新 ,如 
显 式 调 用 UpdatePanel 控件 的 Update 方法 等 条 件 。 

注意 : 不 允许 同时 将 ChildrenAsTriggers 属性 值 设 置 为 False 和 将 UpdateMode 属性 值 
设置 为 Always, 和 否则 会 引发 异常 。 

4. Triggers 属性 

在 例 11. 2 中 ,由 于 TextBoxl 和 Buttonl 控件 都 包含 在 UpdatePanel 控件 中 , 当 发 生 异 步 
回 送 时 不 仅 回 送 了 TextBoxl 的 内 容 , 而 且 回 送 了 Buttonl 的 所 有 代码 ,这 增加 了 网 络 传输 的 
异步 请 求 和 响应 的 数据 量 。 理 想 的 情况 是 应 该 在 UpdatePanel 控件 中 只 包含 TextBoxl 控 
件 ,但 是 如 何 将 UpdatePanel 控件 外 的 Buttonl 控件 定义 为 引发 异步 回 送 的 控件 呢 ? 解决 的 
方法 是 使 用 Triggers 属性 来 定义 触发 器 。 

Triggers 属性 包含 以 声明 方式 为 UpdatePanel 控件 定义 的 AsyncPostBackTrigger 和 
PostBackTrigger 对 象 。 

AsyncPostBackTrigger 对 象 指定 一 个 控件 ,并 将 该 控件 的 可 选 事件 定义 为 导致 UpdatePanel 
控件 刷新 的 异步 回 发 控件 触发 器 。 也 就 是 说 ,AsyncPostBackTrigger 对 象 用 于 使 控件 成 为 
UpdatePanel 控件 的 触发 器 ,而 作为 更 新 面板 触发 器 的 控件 在 异步 回 发 后 导致 面板 内 容 刷新 。 

PostBackTrigger 对 象 将 UpdatePanel 控件 内 部 的 控件 定义 为 回 发 控件 。 使 用 该 对 象 可 
使 UpdatePanel 内 部 的 控件 导致 回 发 ,而 不 是 执行 异步 回 发 。 

UpdatePanel 控件 的 Triggers 属性 可 以 通过 使 用 设计 器 中 的 “UpdatePanelTrigger 集合 
编辑 器 ”对 话 框 或 者 通过 使 用 UpdatePanel 控件 的 王 Triggers 过 元 素 以 声明 方式 定义 触发 器 。 
例如 ,在 网 页 设计 中 进入 UpdatePanell 控件 的 属性 窗口 , 单 击 Triggers 属性 右 侧 的 回 按钮 ， 
出 现 “UpdatePanelTrigger 集合 编辑 器 "对话 框 , 单 击 “添加 ”按钮 ,设置 ControlID 为 “Button1”、 
EventName 为 "Click”( 假 设 网 页 上 有 一 个 不 包含 在 UpdatePanel 控件 中 的 Buttonl 控件 ) ,如 
图 11. 9 所 示 , 单 击 “ 确 定 ” 按 钮 ,此 时 UpdatePanell 控件 包含 如 下 HTML 标记 : 

<Triggers> 
<asp:AsyncPostBackTrigger ControlID = "Button1"” EventName = "Click" /> 

</Triggers > 

这 样 在 网 页 运行 时 单 击 Buttonl 和 该 控件 包含 在 UpdatePanell 控件 中 的 效果 是 一 样 的 。 

ScriptManager 控件 提供 了 RegisterAsyncPostBackControl 方法 用 于 将 控件 注册 为 异步 
回 发 的 触发 器 。 上 述 操 作 等 价 于 如 下 语句 : 


ScriptManager1.RegisterRhsyncPostBackControl(Buttonl ) ; 


5. Update 方法 

该 方法 导致 更 新 UpdatePanel 控件 的 内 容 。 如 果 网 页 允许 部 分 页 面 呈 现 , 则 在 调用 
Update 方法 时 会 在 浏览 器 中 更 新 UpdatePanel 控件 的 内 容 。 如 果 要 使 用 Update 方法 ,需要 
将 UpdateMode 属性 设置 为 Conditional; 如 果 要 决定 更 新 用 服务 器 逻辑 中 的 面板 ,要 确保 
ChildrenAsTriggers 属性 为 False, 并 且 没 有 为 该 面板 定义 显 式 触 发 器 。 

在 典型 的 网 页 设计 中 .如果 为 UpdatePanel 控件 定义 了 和 触发 器 .或 者 该 控件 的 
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图 11.9 “UpdatePanelTrigger 集合 编辑 器 ”对话 框 


ChildrenAsTriggers 属性 为 True, 则 会 在 网 页 生命 周期 期 间 自 动 调 用 Update 方法 。 

【 例 11.3】 创建 一 个 AJAX 网 页 WebForm3, 其 功能 是 在 自 上 次 更 新 以 来 至 少 经 过 5 秒 
后 使 用 Update 方法 更 新 UpdatePanel 控件 的 内 容 。 

解 : 其 步骤 如 下 。 

@ 打开 chll 网 站 ,添加 一 个 代码 隐藏 页 模型 的 网 页 WebForm3. aspx。 

@ 其 设计 界面 中 包含 一 个 ScriptManagerl 控件 和 一 个 UpdatePanell 控件 。 
UpdatePanell 控件 中 包含 一 个 HTML 标签 和 一 个 二 % 二 LastUpdate. ToString() % 之 时 间 
域 。 在 UpdatePanell 控件 外 有 一 个 HTML 标签 和 一 个 毛色 = DateTime. Now. ToString() 
凶 过 时 间 域 ,另外 有 一 个 命令 按钮 Button1。 该 网 页 二 body 二 部 分 的 源 视图 代码 如 下 : 


<body> 
<form id= "forml" runat = "server"> 
<div> 
<asp:ScriptManager ID = "ScriptManagerl”runat = "server"> 
</asp: ScriptManager > 
</div> 
<div> 
<asp:UpdatePanel ID = "UpdatePanell" runat = "server"> 
<ContentTemplate> 
< span class = "auto - stylel"> 
最 近 更 新 时 刻 : <% = LastUpdate.ToString() %></span> 
</ContentTemplate> 
</asp:UpdatePanel > 
</div> 
<div class = "auto— stylel"> 
<br/> 
运行 启动 时 刻 : <% = DateTime.Now.ToString() %> 
<br /><br /> 
<asp:Button ID ="Button1”runat = "server" OnClick = "Buttonl_Click" 
style = "color: # FF0000; font - size:medium; font — weight:700;font - family: 黑 体 " 
Text = " 单 击 " /> 
</div> 
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</form> 
</body> 


说 明 : 二 % 二 …% 汪 其 实 是 ASP 时 代 就 支持 的 绑 定 方式 ,在 ASP.NET 中 这 个 表达 式 依 
然 可 以 使 用 。 通 过 包含 在 二 和 % 汪 中 的 表达 式 将 执行 结果 输出 到 客户 浏览 器 ,如 
二 % 二 test % 沁 就 是 将 变量 test 的 值 发 送 到 客户 浏览 器 中 。 

@ 在 网 页 上 设计 如 下 事件 处 理 过 程 和 一 个 LastUpdate 属性 : 


protected void Page_Load( object sender, EventArgs e) 

{ ScriptManager1. RegisterAsyncPostBackControl (Button1); 
UpdatePanell. UpdateMode = UpdatePanelUpdateMode. Conditional; 
if (!IsPostBack) 

LastUpdate = DateTime. Now; 

} 

protected void Button1_Click(object sender, EventArgs e) 

{ if (LastUpdate. AddSeconds(5.0) < DateTime. Now) 

{ UpdatePanell.Update(); 
LastUpdate = DateTime. Now; 
} 

} 

protected DateTime LastUpdate // 设 置 一 个 属性 

{ get 
{ if (ViewState["LastUpdate"] == null) 

return DateTime. Now; 
else 
return (DateTime) (ViewState[ "LastUpdate" ]); 


set 
{ ViewState["LastUpdate"] = value; } 
} 
@ 单 击 工 具 栏 中 的 Pp Inmternet Explorer 按钮 运行 本 网 页 ,初始 界面 如 图 11. 10 所 示 ,立即 单 击 
“ 单 击 ? 命 令 按钮 时 界面 没有 任何 变化 ,只 有 在 间隔 5 秒 后 再 单 击 才 会 刷新 页 面 , 如 图 11. 11 所 
示 是 经 过 若干 时 间 后 单 击 * 单 击 ” 命 令 按钮 后 的 结果 ,这 是 通过 调用 UpdatePanell. Update( ) 
方法 实现 的 ,而 下 方 的 时 间 域 总 是 保持 不 变 , 因 为 该 时 间 域 不 包含 在 UpdatePanell 控件 中 ,从 
而 得 不 到 刷新 。 


el x 


es ly 
httpy/localhost5147 P= CO| i 缚 hapy/localhost6147 PDP-0|1 
x x 


最 近 更 新 时 刻 : 2015/4/27 15:11:32 | 最 近 更 新 时 刻 : 2015/4/27 15:12:45 


运行 启动 时 刻 : 2015/4/27 15:11:32 运行 启动 时 刻 : 2015/4/27 15:11:32 


图 11. 10 WebForm3 网 页 运行 界面 一 图 11. 11 WebForm3 网 页 运行 界面 二 


在 一 个 网 页 中 还 可 以 放置 多 个 UpdatePanel 控件 ,每 个 UpdatePanel 控件 可 以 实现 独立 
的 局 部 刷新 功能 ,其 用 法 与 单个 UpdatePanel 控件 类 似 。 


11.2.4 ”UpdateProgress 控件 
通常 使 用 UpdateProgress 控件 来 显示 部 分 页 面 更 新 的 进度 。 如 果 网 页 包含 UpdatePanel 
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控件 , 则 可 以 包含 UpdateProgress 控件 来 通知 用 户 部 分 页 面 更 新 的 状态 。 用 户 可 以 使 用 一 个 
UpdateProgress 控件 来 表示 整个 网 页 的 部 分 页 面 更 新 的 进度 ,也 可 以 为 每 个 UpdatePanel 控 
件 包 含 一 个 UpdateProgress 控件 。 

1. ProgressTemplate 属性 

该 属性 获取 或 设置 用 于 定义 UpdateProgress 控件 内 容 的 模板 。 也 就 是 说 , 使 用 
ProgressTemplate 属性 可 以 指定 由 UpdateProgress 控件 显示 的 消息 。 

如 果 ProgressTemplate 属性 为 空 , 则 在 显示 UpdateProgress 控件 时 不 会 显示 任何 内 容 。 

UpdateProgress 控件 模板 的 显示 与 UpdateProgress 控件 所 在 的 位 置 无 关 。 

2. DisplayAfter 属性 

该 属性 获取 或 设置 显示 UpdateProgress 控件 之 前 所 经 过 的 时 间 值 (以 毫秒 为 单位 ) 。 

默认 情况 下 ,UpdateProgress 控件 会 在 显示 其 内 容 之 前 等 待 0. 5 秒 (500 毫秒 ) 。 在 异步 
回 发 的 速度 很 快 时 ,通过 设置 DisplayAfter 属性 可 指定 延迟 ,这 有 助 于 防止 控件 闪烁 。 

【 例 11.4】 创建 一 个 AJAX 网 页 WebForm4 ,其 功能 是 说 明 UpdateProgress 控件 的 
ProgressTemplate 和 DisplayAfter 属性 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

@ 打开 chll 网 站 ,添加 一 个 代码 隐藏 页 模型 的 网 页 WebForm4. aspx。 

@ 其 设计 界面 如 图 11. 12 所 示 , 其 中 包含 一 个 rr 
ScriptManagerl 控件 ,一 个 UpdatePanell 控件 和 一 个 ~ 
UpdateProgressl 控件 ,UpdatePanell 控件 中 包含 一 个 一 | | 
标签 Labell ,UpdateProgressl 控件 中 包含 一 个 Imagel | 
图 像 控 件 和 一 个 HTML 文本 标记 ,最 下 方 有 一 个 命令 ”| 这 网 | 
按钮 Button1。 该 网 页 二 body 二 部 分 的 源 视图 代码 如 
下 ( 粗 体 部 分 包含 UpdateProgressl 控件 的 [st a 拆 分 |。 源 | [<aspiUpdateprog 
ProgressTemplate 属性 ): 


图 11.12 WebForm4 网 页 设计 界面 
<body> 
<form id= "forml" runat = "server"> 
<div> 
<asp:ScriptManager ID = "ScriptManagerl" runat = "server"></asp:ScriptManager > 
< asp: UpdateProgress ID = "UpdateProgressl”runat = " server"> 
< ProgressTemplate> 
< asp: Image ID = "Imagel" runat ="server" Height = "25px" 
ImageUrl = "~ /Images/ imgl. jpg" Width = "25px" /> 
Snbsp;< span class = "auto - stylel"> 请 等 待 ...</span> 
</ProgressTemplate > 
</asp: UpdateProgress> 
</div> 
<div> 
<asp:UpdatePanel ID = "UpdatePanell" runat = "server"> 
< ContentTemplate > 
<asp:Label ID = "Labell" runat = "server" style= "color: ##FFOOFF; 
font - size: medium; font— weight: 700; font- family: 仿宋 "></asp:Label > 
</ContentTemplate > 
<Triggers> 
<asp:AsyncPostBackTrigger ControlID = "Button1”EventName = "Click" /> 
</Triggers> 
</asp:UpdatePanel > 
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</div> 
<div> 
<br /> 
<asp:Button ID = "Buttonl" runat = "server" OnClick = "Buttonl Click" 
style = "color: #FF0000; font— size: medium; font — weight: 700; 
font - family: 黑体 ”Text = "开始 " /> 
</div> 
</form> 
</body> 


@ 在 网 页 上 设计 如 下 事件 处 理 过 程 : 


protected void Page_Load( object sender, EventArgs e) 

‘ 
UpdateProgressl. DisplayAfter = 2000; 

} 

protected void Button1_Click(object sender, EventArgs e) 

{ System.Threading.Thread.Sleep(10000); // 休 眼 10 秒 钟 
Labell. Text = "完成 时 刻 : " + DateTime. Now. ToString(); 

} 


说 明 : System. Threading. Thread. Sleep(10000) 语 和 句 是 调用 System. Threading 命名 空 
间 中 的 Thread 线程 类 的 Sleep 方法 ,其 作用 是 等 待 10 秒 ,用 来 模拟 长 时 间 运 行 过 程 。 
UpdateProgressl. DisplayAfter 一 2000 语句 在 网 页 启动 后 过 两 秒 显示 UpdateProgressl 控件 
面板 。 

@ 单 击 工具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,然后 单 击 “ 开 始 ” 命 令 按 钮 ,过 两 秒 后 
出 现 如 图 11. 13 所 示 的 界面 ,再 过 10 秒 出 现 如 图 11. 14 所 示 的 界面 。 


图 11.13 WebForm4 网 页 运行 界面 一 图 11.14 WebForm4 网 页 运行 界面 二 


3. AssociatedUpdatePanellD 属性 

该 属性 获取 或 设置 UpdateProgress 控件 显示 其 状态 的 UpdatePanel 控件 的 ID。 在 一 个 
网 页 中 可 以 放置 多 个 UpdateProgress 控件 ,通过 设置 AssociatedUpdatePanelID 属性 可 以 使 
每 个 UpdateProgress 控件 与 单个 UpdatePanel 控件 关联 。 

当 回 发 事件 源 于 UpdatePanel 控件 内 部 时 会 显示 所 有 关联 的 UpdateProgress 控件 。 如 
果 没 有 设置 AssociatedUpdatePanelID 属性 , 则 UpdateProgress 控件 会 为 源 于 任何 
UpdatePanel 控件 内 部 的 任何 异步 回 发 显示 进度 ,还 会 为 充当 面板 触发 器 的 任何 控件 显示 进度 。 

AssociatedUpdatePanelID 属性 对 UpdateProgress 控件 行为 具有 以 下 影响 : 

。 如 果 没 有 设置 AssociatedUpdatePanelID 属性 , 则 为 以 下 回 发 显示 UpdateProgress 控 

件 : 源 于 任何 UpdatePanel 控件 内 部 的 回 发 和 源 于 充当 任何 UpdatePanel 控件 的 异步 
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触发 器 的 控件 的 回 发 。 


。 如 果 将 AssociatedUpdatePanelID 属性 设置 为 UpdatePanel 控件 ID , 则 会 为 源 于 关联 
UpdatePanel 控件 内 部 的 回 发 显示 UpdateProgress 控件 。 

如 果 将 AssociatedUpdatePanelID 属性 设置 为 不 存在 的 控件 , 则 永远 不 会 显示 
UpdateProgress 控件 。 如 果 将 UpdatePanel 控件 的 ChildrenAsTriggers 属性 设置 为 False, 而 
回 发 源 于 UpdatePanel 控件 内 部 , 则 仍 会 显示 任何 关联 的 UpdateProgress 控件 。 

【 例 11.5】 创建 一 个 AJAX 网 页 WebForm5 ,其 功能 是 说 明 UpdateProgress 控件 的 
AssociatedUpdatePanelID 属性 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

Q@ 打开 chll 网 站 ,添加 一 个 代码 隐藏 页 模型 的 网 页 WebForm5. aspx。 

@ 其 设计 界面 如 图 11.15 所 示 ,其 中 包含 一 个 ScriptManagerl 控件 和 两 组 UpdatePanel 
控件 。 

第 1 组 UpdatePanell 控件 中 包含 一 个 UpdateProgressl 控件 (其 中 有 一 个 HTML 文本 
标记 ) 一 个 标签 Labell 和 一 个 命令 按钮 Button1(Text 为 “任务 1”) ,并 设置 UpdateProgress1 
的 AssociatedUpdatePanelID 属性 为 UpdatePanell 。 

第 2 组 UpdatePanel2 控件 中 包含 一 个 UpdateProgress2 控件 (其 中 有 一 个 HTML 文本 
标记 ) 一 个 标签 Label2 和 一 个 命令 按钮 Button2(Text 为 “任务 2”) ,并 设置 UpdateProgress2 
的 AssociatedUpdatePanelID 属性 为 UpdatePanel2。 

该 网 页 一 body 之 部 分 的 源 视图 代码 如 下 : 


<body > 
<form id= "forml" runat = "server"> 
<div> 
<asp:ScriptManager ID = "ScriptManagerl1l" runat = "server"> 
</asp: ScriptManager > 
</div> 
<div style = "color: 井 800080; font - size: medium; font - family: 仿宋 "> 
<asp:UpdatePanel ID = "UpdatePanell" runat = " server"> 
< ContentTemplate > 
<asp:UpdateProgress ID = "UpdateProgress1l" runat = "server" 
RssociatedUpdatePanelID = " UpdatePane11"> 
<ProgressTemplate > 任务 1: 请 等 待 ...</ProgressTemplate> 
</asp:UpdateProgress > 
<asp:Label ID = "Labell" runat = "server" CssClass = "auto - stylel" /> 
<br /><br /> 
<asp:Button ID = "Button1" runat = "server" CssClass = "auto— style2" 
Text = "任务 1" OnClick = "Buttonl_Click" /> 
</ContentTemplate > 
</asp:UpdatePanel > 
</div> 
<div style= "color: 井 800080; font - size: medium; font - family: 仿宋 "> 
<asp:UpdatePanel ID = "UpdatePanel2" runat = "server"> 
< ContentTemplate > 
<asp:UpdateProgress ID = "UpdateProgress2”runat = "server" 
RssociatedUpdatePanelID = " UpdatePane12"> 
<ProgressTemplate > 任务 2: 请 等 待 ...</ProgressTemplate> 
</asp:UpdateProgress > 
<asp:Label ID = "Label2" runat = "server" CssClass= "auto— stylel" /> 
<br/><br/> 
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<asp:Button ID = "Button2" runat = "server" CssClass = "auto— style2" 
Text = "任务 2" OnClick = "Button2_Click" /> 
</ContentTemplate> 
</asp:UpdatePanel > 
</div> 
</form> 


</body > 
@ 在 网 页 上 设计 如 下 事件 处 理 过 程 : 


protected void Button1_Click(object sender, EventArgs e) 
{ System. Threading. Thread. Sleep( 5000); 

Labell. Text = "任务 1 完成 时 间 : " + DateTime. Now. ToString(); 
} 
protected void Button2_Click(object sender, EventArgs e) 
{ System.Threading.Thread.Sleep(5000); 

Label2. Text = "任务 2 完成 时 间 : " + DateTime. Now. ToString(); 
} 


@ 单 击 工具 栏 中 的 上 Internet Explorer 按钮 运行 本 网 页 ,然后 单 击 " 任 务 1” 命 令 按 钮 ,出 现 如 
图 11.16 所 示 的 界面 ,过 5 秒 后 出 现 如 图 11. 17 所 示 的 界面 ,过 一 会 再 单 击 “ 任 务 2” 命 令 按 
钮 ,最 后 的 结果 如 图 11. 18 所 示 。 

从 中 可 以 看 到 ,两 个 UpdateProgress 控件 分 别 显示 两 个 UpdatePanel 控件 的 进度 ,它们 
相互 之 间 没 有 影响 ,都 是 单独 执行 异步 回 送 。 
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图 11.15 WebForm5 网 页 设计 界面 图 11.16 WebForm5 网 页 运行 界面 一 
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任务 2 完成 时 间 : 2015/4/28 8:07:00 


图 11.17 WebForm5 网 页 运行 界面 二 11.18 ”WebForm5 网 页 运行 界面 三 
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11.2.5 Timer 控件 


Timer 控件 按照 定义 的 时 间 间 隔 执行 异步 网 页 回 发 或 同步 网 页 回 发 ,其 主要 的 属性 和 事 
件 如 下 。 
。 Interval 属性 : 用 于 指定 回 发 发 生 的 频率 ,以 毫秒 (ms) 为 单位 ,其 默认 值 为 60 000ms 
(Bh 60s) 。 
。 Enabled 属性 : 用 于 打开 或 关闭 Timer, 默 认为 True。 
。 Tick 事件 : 在 经 过 Interval 属性 中 指定 的 毫秒 数 并 向 服务 器 发 送 网 页 时 引发 。 
【 例 11.6】 创建 一 个 AJAX 网 页 WebForm6 ,其 功能 是 说 明 Timer 控件 的 使 用 方法 。 


解 : 其 步骤 如 下 。 

@ 打开 chll 网 站 ,添加 一 个 代码 隐藏 页 模型 的 网 页 WebForm6. aspx。 

@ 其 设计 界面 如 图 11. 19 所 示 ,其 中 包含 一 个 ScriptManagerl 控件 ,一 个 UpdatePanell 
控件 和 一 个 Timerl 控件 , UpdatePanell 控件 中 包含 一 个 HTML 文本 标记 和 一 个 标签 
Labell ,设置 Timerl 控件 的 Interval 属性 为 5000。 该 网 页 一 body> 部 分 的 源 视图 代码 如 下 


<body > 
<form id= "forml" runat = "server"> 
<div> 
<asp:ScriptManager ID= "ScriptManagerl" runat = "server"> 
</asp:ScriptManager > 
<asp:Timer ID = "Timerl" runat = "server" 
OnTick = "Timerl Tick" Interval ="5000"></asp:Timer> 
</div> 
<div style = "color: #FFOOFF;font - size:medium;font - weight:700;font - family: 仿 宋 "> 
<asp:UpdatePanel ID = "UpdatePanell" runat = "server"> 
<ContentTemplate> 
当前 时 间 : <asp:Label ID= "Labell" runat = "server"></asp:Label > 
</ContentTemplate > 
</asp: UpdatePanel > 
</div> 
</form> 
</body> 


@ 在 网 页 上 设计 如 下 事件 处 理 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
[ if (!Page. IsPostBack) 
Labell. Text = DateTime. Now. ToString(); 


; 
protected void Timerl1_Tick(object sender, EventArgs e) 


{ 
Labell. Text = DateTime. Now.ToString(); 


} 

@ 单 击 工具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,出 现 如 图 11. 20 所 示 的 界面 。 每 间 
隔 5 秒 刷新 一 次 显示 时 间 。 

有 关 网 页 刷新 的 问题 ,如 果 本 例 不 用 AJAX 控件 而 是 采用 二 meta http-equiv 王 "Refresh" 
content 二 "5" … /全 的 页 面 指令 ,尽管 可 以 每 5 秒 刷新 一 次 网 页 来 更 新 显示 时 间 , 但 刷新 的 是 
整个 网 页 ,而 不 仅仅 是 Labell 控件 ,这 样 会 导致 页 面 闪 烁 。 
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图 11.19 WebForm6 网 页 设计 界面 一 图 11. 20 WebForm6 网 页 运行 界面 


11.2.6 ScriptManagerProxy 控件 


在 网 页 设计 中 可 以 使 用 嵌 套 网 页 ,如 基于 母 版 页 的 网 页 使 用 的 就 是 这 种 设计 方法 。 当 在 
母 版 页 中 添加 了 ScriptManager 控件 时 ,所 有 使 用 该 母 版 页 的 内 容 页 都 支持 AJAX 功能 。 因 
为 一 个 网 页 只 能 有 一 个 ScriptManager 控件 ,不 能 在 内 容 页 中 同时 使 用 ScriptManager 控件 ， 
而 且 只 有 母 版 页 才能 有 二 head> 元 素 , 使 得 在 很 多 情况 下 内 容 页 引用 . js 等 不 那么 方便 ,为 此 
ASP.NET 提供 了 ScriptManagerProxy 控件 。 

如 果 要 在 某 个 内 容 页 中 将 额外 的 脚本 或 服务 添加 到 ScriptManager 控件 所 定义 的 脚本 或 
服务 集合 中 ,就 可 以 使 用 ScriptManagerProxy 控件 。 也 就 是 说 ,ScriptManagerProxy 控件 可 
以 在 母 版 页 或 父 元 素 中 已 定义 ScriptManager 控件 时 将 新 增 的 脚本 或 服务 添加 到 内 容 页 或 用 
户 控件 中 。 

ScriptManagerProxy 控件 的 主要 属性 如 下 。 

。 Scripts 属性 : 获取 一 个 ScriptReferenceCollection 对 象 (ScriptReference 对 象 的 集合 ) ,该 对 

象 包含 显 式 注 册 到 ScriptManagerProxy 控件 的 每 个 脚本 文件 的 ScriptReference 对 象 。 
。 Services 属性 : 获取 一 个 ScriptReferenceCollection 对 象 .该 对 象 包含 显 式 注 册 到 
ScriptManagerProxy 控件 的 每 个 Web 服务 的 ServiceReference 对 象 。 

例如 ,要 在 内 容 页 中 将 脚本 程序 myscript, js 添加 到 ScriptManager 控件 (来 自 母 版 页 ) 所 

定义 的 脚本 和 服务 集合 中 ,可 以 使 用 ScriptManagerProxy 控件 来 实现 。 对 应 的 代码 如 下 : 


<asp:ScriptManagerProxy ID = "ScriptManagerProxyl" runat = "server"> 
<Scripts> 
<asp: ScriptReference Path= "myscript. js" /> 
</Scripts> 
</asp: ScriptManagerProxy> 
从 上 看 到 ,ScriptManager 和 ScriptManagerProxy 是 两 个 非常 相似 的 控件 ,只 是 后 者 用 于 
内 容 页 或 子 网 页 中 。 需 要 注意 的 是 ,如 果 在 内 容 页 上 使 用 ScriptManagerProxy 控件 ,但 母 版 
页 上 没有 ScriptManager 控件 ,那么 就 会 出 错 。 


11.2.7 AJAX 控件 应 用 示例 
【 例 11.7】 创建 一 个 AJAX 网 页 WebForm7 ,其 功能 是 使 用 AJAX 控件 改进 例 5.7 的 简 
单 的 聊天 室 设计 。 


解 : 其 步骤 如 下 。 
@ 打开 chll 网 站 ,添加 一 个 代码 隐藏 页 模型 的 网 页 WebForm6. aspx。 
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@ 其 设计 界面 如 图 11. 21 所 示 ,其 中 包含 一 个 ScriptManagerl 控件 ,一 个 UpdatePanell 
控件 和 一 个 Timerl 控件 ,UpdatePanell 控件 中 包含 一 个 文本 框 chatBox( 大 小 为 200pxX 
500px,TextMode 属性 置 为 MultiLine, ReadOnly 属性 置 为 True), 设 置 Timerl 控件 的 


Interval 属性 为 10000。 网 页 下 方 有 两 个 文本 框 TextBoxl 和 TextBox2 ,用 于 输入 姓名 和 聊天 
内 容 。 该 网 页 的 源 视图 代码 如 下 : 


<% @Page Language = "C#" AutoEventWireup = "true" CodeFile = "WebForm7.aspx.cs" 
Inherits= "WebForm7" %> 
<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head runat = "server"> 


<meta http - equiv= "Content- Type" content = "text/htm1; charset = utf — 8"/> 


<title></title> 
<script> 
function setPosition(obj) 
{ varrng = obj.createTextRange(); // 为 object 建立 TextRange 对 象 
rng. moveStart("character"，obj. value. length); // 设 置 更 改 范围 的 开始 位 置 
rng. collapse(true); // 将 插入 点 移动 到 当前 范围 的 末尾 
rng. select(); // 将 当前 选择 区 置 为 当前 对 象 
} 
</script > 
</head> 
<body> 


<form id= "forml" runat = "server"> 
<asp:ScriptManager ID = "ScriptManagerl" runat = "server"> 
</asp:ScriptManager > 
<asp:Timer ID = "Timerl" runat = "server" 
Interval ="10000" OnTick = "Timerl Tick"> 
</asp:Timer > 
<div style = "color:#e30af3; font— size: x- large; font ~ weight: 700; 
font - family: 隶书 "> 
可 自动 刷新 的 简单 聊天 室 


Timer - Timerl 


[Edaepanesupdarad 育 -攻关 全  _ 


ScriptManager - ScriptManagerl 


姓名 : 内 容 : [要 交 | 


4 
5 设计 |e 拆 分 |。 源 | pl <asp:UpdatePanel#UpdatePa...> 上 


图 11.21 WebForm7 网 页 设计 界面 
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</div> 
<div> 
<asp:UpdatePanel ID = "UpdatePanell" runat = "server"> 
< ContentTemplate > 
<asp:TextBox ID = "chatBox" runat = "server”BorderStyle = "Inset" 
Height = "200px" ReadOnly = "True"” 
style = "color: #800080; font - size: medium; font ~ weight: 400; 
font- family: 仿宋 " TextMode = "MultiLine" Width = "500px" 
onfocus = "setPosition(this)" /> 
</ContentTemplate> 
</asp:UpdatePanel> 
</div> 
<div style = "color: 井 0000FF; font - size: medium; font ~ weight: 700; 
font - family: 楷体 "> 
<br /> 
姓名 : <asp:TextBox ID = "TextBoxl" runat = "server" Width= "83px" /> 
&nbsp; 内 容 : 
<asp:TextBox ID= "TextBox2" runat = "server" Height = "42px" 
TextMode = "MultiLine" Width = "189px" onfocus = "setPosition(this)" /> 
Snbsp; gnbsp; 
<asp:Button ID= "Buttonl" runat = "server" OnClick = "Buttonl_Click" 
style= "color: #3FF0000;font— size: medium; font - weight: 700; 
font - family: 黑体 ; height: 26px;"” Text = "提交 " Width= "61px" /> 
</div> 
</form> 
</body> 
</html > 


其 中 ,客户 端 JavaScript 脚本 setPosition(obj) 函数 作用 于 chatBox 和 TextBox2 控件 , 当 
多 行文 本 框 获得 焦点 时 自动 将 插入 点 移动 到 文本 末尾 。 
@ 在 网 页 上 设计 如 下 事件 处 理 过 程 : 


protected void Application_Start(object sender, EventArgs e) 


{ Application["chats"] = null; // 聊 天 记录 置 空 
Application[ "chatnum"] = null; // 聊 天 记录 数 置 空 

} 

protected void Application_End(object sender, EventArgs e) 

{ Application["chats"] = null; // 聊 天 记录 清空 
Application[ "chatnum"] = null; // 聊 天 记录 数 清空 

} 


protected void Page_Load( object sender, EventArgs e) 
| if (!Page. IsPostBack) 
{ Session["mynum"] = Application["chatnum"]; // 用 于 计算 我 的 聊天 记录 数 
if (Application["chats"] != null) 
{ chatBox. Text = Application["chats"].ToString(); 
chatBox. Focus( ); 


} 
protected void Button1_Click(object sender, EventArgs e) 
{ int chatnum, mynum; 
if (TextBox]. Text != "" && TextBox2.Text != "") 
{ Application.Lock(); 
if (Application["chatnum"] == null) 
{ chatnum = 0; 


} 


} 


else 
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mynum = 0; 
于 
else 
{ chatnum = int.Parse(Application["chatnum"].ToString()); 
mynum = int.Parse(Session[ "mynum"].ToString()); 
} 
证 (chatnum % 5 == 0) // 每 5 条 聊天 记录 添加 时 间 
{ if (chatnum == 0) 
Application["chats"] = TextBoxl.Text + "说 :" + TextBox2. Text + 
"[" + DateTime.Now.ToString() + "]."; 
else 
Application[ "chats"] = Application["chats"] +"\n"+ TextBoxl.Text + 
"说 :"” + TextBox2. Text + "[" + DateTime. Now.ToString() + "]."; 
} 
else 
Application[ "chats"] = Application["chats"] +"\n"+ TextBoxl. Text + 
"说 :" + TextBox2. Text + "."，; 
chatnum++; 
object obj = chatnum; 
Application[ "chatnum"] = obj; 
mynum++; 
obj = mynum; 
Session[ "mynum"] = obj; 
Applicat ion. UnLock( ); 
chatBox. Text = Application["chats"].ToString(); 
ChatBox. Focus( ); 


Response. Write("< script > alert(' 必 须 输入 姓名 和 聊天 内 容 ')</script >"); 


protected void Timerl_Tick( object sender, EventArgs e) 
if (TextBoxl.Text != "" && Application["chatnum"] != null) 


{ 


} 


{ 


} 


int chatnum = int.Parse(Application["chatnum"].ToString()); 
int mynum = int.Parse(Session["mynum"].ToString()); 
if (mynum < chatnum) // 有 其 他 人 的 聊天 记录 时 刷新 chatBox 
{ chatBox.Text = (string)Application["chats"]; 
chatBox. Focus( ); 
} 
else TextBox2. Focus( ); 


else TextBox2. Focus( ); 


当 一 个 客户 运行 本 网 页 时 开始 一 个 会 话 , 置 Session["mynum"] 为 Application 
[L"chatnum"]( 即 该 客户 会 话 前 的 聊天 记录 数 ), 每 次 该 客户 提交 一 条 聊天 记录 , Session 
已 mynum"] 和 Application[ "chatnum"] 均 增加 1, 当 其 他 客户 聊天 时 Application[ "chatnum"] 
会 增加 ,而 该 客户 的 SessionL"mynum"j 不 会 增加 。 所 以 ,在 Timerl_Tick 事件 处 理 过 程 中 ， 
只 有 当 Session["mynum"] 小 于 Application["chatnum"] ,说 明 有 其 他 客户 在 聊天 ,此 时 才 刷 
新 chatBox 的 内 容 , 从 而 最 大 限度 地 减少 刷新 次 数 。 

@ 单 击 工具 栏 中 的 上 Imiemet Explorer 按钮 运行 本 网 页 ,其 聊天 界面 如 图 11. 22 所 示 。 

和 例 5.7 相 比 ,该 例 主要 有 3 点 改进 : 


O 


由 于 采用 客户 端 脚 本 定位 多 行文 本 框 的 插入 点 ,聊天 记录 按 聊 天 顺序 显示 ,用 户 每 次 
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王 华 说 :大 家 好 [2015/4/29 9:40:25]. 


好 的 ， 再 见 


十 名 : 内 容 : 


图 11.22 WebForm? 网 页 运行 界面 


都 能 看 到 最 新 的 聊天 记录 。 

@ 采用 AJAX 控件 实现 屏幕 部 分 自动 刷新 ,消除 闪烁 现象 。 

@ 智能 化 检测 是 否 有 其 他 客户 的 聊天 记录 ,只 有 在 检测 到 其 他 客户 聊天 记录 时 才 实施 
刷新 。 


11.3 AJAX 控件 工具 集 


ASP.NET AJAX 控件 不 像 Web 标准 服务 器 控件 那么 多 ,原因 是 Microsoft 把 它们 当 作 
开放 源 代码 的 项 目 , 而 不 是 把 它们 融合 到 Visual Studio 2012 中 。Microsoft 及 其 社区 中 的 开 
发 人 员 开 放 了 一 系列 支持 AJAX 的 可 以 在 ASP.NET 应 用 程序 中 使 用 的 服务 器 控件 , 称 之 为 
A 控件 工具 集 。 它 们 位 于 CodePlex 中 ,网 址 是 “http://ajaxcontroltoolkit. codeplex. 

。 用 户 可 以 从 该 网 址 下 载 并 安装 ,这 样 从 Visual Studiio 2012 的 工具 箱 中 就 可 以 看 到 这 

Pepa 

AJAX 控件 工具 集中 常用 的 AJAX 控件 如 下 。 

。 Accordion: 可 折 共 面板。 
AjaxFileUpload: 文件 上 传 , 支 持 上 传 进度 的 显示 ,大 文件 上 传 .文件 拖 放 上 传 等 。 
。 AlwaysVisibleControlExtender: 将 指定 的 控件 悬浮 在 固定 位 置 。 
。 AnimationExtender: 产生 与 Flash 媲美 的 JavaScript 动画 。 
。 AreaChart: 产生 一 个 或 多 个 系列 的 面积 图 。 
。 AsyncFileUpload: 异步 文件 上 传 。 
。 AutoCompleteExtender: 扩展 TextBox 控件 ,通过 Web 服务 显示 包含 文本 框 输入 值 

的 数据 。 

。 BalloonPopupExtender: 扩展 TextBox 控件 ,在 文本 框 获得 焦点 时 弹出 提示 信息 。 
。 BarChart: 产生 一 个 或 多 个 系列 的 条 形 图 。 
。 BubbleChart: 产生 一 个 或 多 个 系列 的 气泡 图 。 
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CalendarExtender: 扩展 TextBox 控件 ,在 文本 框 获得 焦点 时 弹出 输入 日 历 的 界面 。 
CascadingDropDown: 扩展 DropDownList 控件 ,实现 级 联 式 自动 填充 数据 。 
CollapsiblePanelExtender: 提供 可 折 释 面板 的 效果 。 

ColorPickerExtender: 扩展 TextBox 控件 ,在 文本 框 获得 焦点 时 弹出 选择 颜色 的 
界面 。 

ComboBox: 实现 组 合 框 功能 。 

ConfirmButtonExtender: 扩展 Button 控件 , 单 击 Button 控件 时 弹出 确认 提示 框 。 
DragPanelExtender: 自由 拖 动 面板 。 

DropDownExtender: 提供 SharePoint 样式 下 拉 菜 单 。 

DropShadowExtender: 提供 投影 效果 的 面板 。 

DynamicPopulateExtender: 将 Web 服务 返回 的 数据 动态 地 呈现 在 控件 上 。 
FilteredTextBoxExtender: 扩展 TextBox 控件 ,可 以 防止 用 户 输入 无 效 字 符 。 
Gravatar: 显示 gravatar 类 型 图 片 。 

HoverMenuExtender: 显示 包含 可 执行 操作 的 弹出 面板 。 

HTMLEditorExtender: 扩展 TextBox 控件 ,提供 HTML5 编辑 功能 。 

LineChart: 产生 一 个 或 多 个 系列 的 线形 图 。 

ListSearchExtender: 扩展 List 类 控件 ,提供 输入 值 后 自动 搜索 的 功能 。 
MaskedEditExtender: 扩展 TextBox 控件 ,提供 指定 格式 的 输入 功能 。 
ModalPopupExtender: 改变 部 分 页 面 的 样式 ,弹出 提示 信息 。 
MutuallyExclusiveCheckBoxExtender: 扩展 CheckBox 控件 ,提供 选择 多 个 排他 性 选 
项 的 功能 。 

NoBot: 拒绝 机 器 人 程序 。 

NumericUpDownExtender: 扩展 TextBox 控件 ,提供 通过 上 下 箭头 输入 数值 的 功能 。 
PagingBulletedListExtender: 扩展 BulletedList 控件 ,提供 客户 端 排序 的 分 页 功能 。 
PasswordStrength: 扩展 TextBox 控件 ,显示 输入 密码 的 强度 。 

PieChart: 产生 一 个 或 多 个 系列 的 饼 图 。 

PopupControlExtender: 弹出 帮助 用 户 输入 的 面板 。 

Rating: 以 星 号 显示 直观 的 评级 信息 。 

ReorderList: 可 以 通过 鼠标 拖 动 改变 条 目 顺 序 。 

ResizableControlExtender: 可 以 拖 放 边框 改变 大 小 的 面板 。 
RoundedCornersExtender: 提供 圆 角 效果 。 

Seadragon: 提供 放大 或 缩小 图 片 的 效果 。 

SliderExtender: 扩展 TextBox 控件 ,提供 通过 滑 块 输入 数值 的 功能 。 
SlideShowExtender: 提供 幻灯 片 放映 的 效果 。 

TabContainer: 提供 选项 卡 的 效果 。 

TextBoxWatermarkExtender: 扩展 TextBox 控件 ,提供 水 印 的 效果 。 
ToggleButtonExtender: 扩展 CheckBox 控件 .通过 图 片 表示 不 同 的 选择 。 
ToolkitScriptManager: 在 使 用 Ajax Control Toolkit 中 的 控件 时 必须 首先 添加 的 管理 
控件 。 

Twitter: 显示 Twitter 状态 信息 。 
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。 UpdatePanelAnimationExtender: 具有 动画 效果 的 局 部 刷新 面板 。 
。 ValidatorCalloutExtender: 增强 验证 控件 功能 。 
上 述 AJAX 控件 的 使 用 方法 与 前 面 介绍 的 ASP.NET AJAX 控件 基本 相同 。 


练习 题 11 


. 简 述 AJAX 的 作用 。 在 什么 情况 下 采用 AJAX 技术 ? 

. 简 述 AJAX 的 工作 原理 。 

简 述 什么 是 ASP.NET AJAX。 

简 述 ScriptManager 控件 的 作用 。 

. 简 述 UpdatePanel 控件 的 作用 。 

. 简 述 UpdateProgress 控件 的 作用 。 

. 简 述 ScriptManagerProxy 控件 的 作用 。 

. 简 述 Timer 控件 的 作用 。 

. 简 述 例 11.7 和 例 5.7 设计 的 聊天 室 在 运行 中 有 什么 不 同 ? 
10. 简 述 Microsoft 为 什么 提供 AJAX 控件 工具 集 。 


上 机 实验 题 11 
在 chll 网 站 中 添加 一 个 名 称 为 Expermentll 的 网 页 ,其 功能 是 用 户 输入 倒计时 秒 数 , 单 


击 “ 开 始 ” 命 令 按 钮 便 开始 倒计时 ,每 过 1 秒 显 示 一 次 剩余 秒 数 , 当 剩 余 秒 数 为 0 时 显示 “时 间 
到 ”。 图 11. 23 所 示 的 是 用 户 输入 10 秒 的 运行 过 程 ,要 求 在 显示 剩余 秒 数 时 不 刷新 网 页 。 


oT 虽 一 


cr 
大 localhost 其 
铜 计时 秒 数 : [10 


[ 卫 风 | 


图 11.23 上 机 实验 题 11 网 页 的 运行 过 程 
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ADO.NET 数据 库 访 问 技术 第 12 章 


ADO.NET 是 一 组 向 .NET Framework 程序 员 公 开 数 据 访问 服务 的 类 。 
ADO. NET 为 创建 分 布 式 数据 共享 应 用 程序 提供 了 一 组 丰富 的 组 件 。 它 提供 
了 对 关系 数据 XML 和 应 用 程序 数据 的 访问 ,因此 是 .NET Framework 中 不 可 
缺少 的 一 部 分 。ADO.NET 支持 多 种 开发 需求 ,包括 创建 由 应 用 程序 .工具 、 语 
言 或 Internet 浏览 器 使 用 的 前 端 数据 库 客 户 端 和 中 间 层 业务 对 象 。 本 章 先 介 
绍 数据 库 的 基本 概念 ,然后 讨论 通过 ADO.NET 访问 SQL Server 2012 数据 库 
的 网 页 设计 技术 。 

本 章 学 习 要 点 : 

回 掌 握 数 据 库 的 基本 概念 ,并 使 用 SQL Server 2012 数据 库 管理 系统 创建 

数据 库 。 

回 掌握 基本 SQL 语句 实现 数据 库 的 操作 。 

回 掌握 ADO.NET 的 体系 结构 和 访问 数据 库 的 方式 。 

回 掌 握 ADO .NET 的 数据 访问 对 象 ,如 SqlConnection、SqlCommand、 

SqlDataReader 和 SqlDataAdapter 等 对 象 的 使 用 方法 。 

加 掌握 DataSet 数据 库 访问 组 件 的 使 用 方法 。 

加 掌握 各 种 数据 源 控件 的 使 用 方法 。 

加 掌握 各 种 数据 绑 定 控件 的 使 用 方法 。 

加 灵活 使 用 ADO.NET 设计 较 复 杂 的 SQL Server 数据 库 访 问 网 页 。 


12.1 数据 库 概 述 

数据 库 用 于 存储 结构 化 数据 。 数 据 组 织 有 多 种 数据 模型 ,目前 主要 的 数据 
模型 是 关系 数据 模型 ,以 关系 模型 为 基础 的 数据 库 就 是 关系 数据 库 。 
12.1.1 关系 数据 库 的 基本 结构 


关系 数据 库 以 表 的 形式 ( 即 关系 ) 组 织 数据 ,关系 数据 库 以 关系 的 数学 理论 
为 基础 。 在 关系 数据 库 中 ,用 户 可 以 不 必 关 心 数 据 的 存储 结构 ,同时 ,关系 数据 
库 的 查询 可 用 高 级 语言 来 描述 ,这 大 大 提高 了 查询 效率 。 
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下 面 讨论 关系 数据 库 的 基本 术语 。 

各 ' 替 

表 用 于 存储 数据 , 它 以 行列 方式 组 织 , 可 以 使 用 SQL 从 中 获取 修改 和 删除 数据 。 表 是 关 
系数 据 库 的 基本 元 素 。 表 在 现实 生活 中 随处 可 见 , 如 职工 表 、 学 生 表 和 统计 表 等 。 表 具有 直 
观 、 方 便 和 简单 的 特点 。 表 12. 1 是 一 个 学 生 情 况 表 student, 其 中 “学 号 ”为 主键 。 表 12. 2 是 
一 个 学 生成 绩 表 score, 其 中 “学 号 十 课程 名 ”为 主键 。 从 中 可 以 看 到 , 表 是 一 个 二 维 结构 , 行 和 
列 的 顺序 并 不 影响 表 的 内 容 。 

表 12.1 学 生 情况 表 student 


学 号 姓名 性 别 民族 班 号 
1 王 华 女 汉族 09001 
2 孙 丽 女 满族 09002 
3 李兵 男 汉族 09001 
6 张 军 男 汉族 09001 
8 马 棋 男 回族 09002 


表 12.2 学 生成 绩 表 score 


学 号 课程 名 分 数 学 号 课程 名 分 数 
C 语言 80 1 数据 结构 57 
2 C 语言 70 : 数据 结构 52 
3 C 语言 89 3 数据 结构 84 
6 C 语言 90 6 数据 结构 95 
8 C 语言 88 8 数据 结构 86 
2. 记录 


记录 是 指 表 中 的 一 行 , 在 一 般 情况 下 ,记录 和 行 的 意思 是 相同 的 。 在 表 12. 1 中 ,每 个 学 生 
所 占据 的 一 行 是 一 个 记录 ,描述 了 一 个 学 生 的 情况 。 

3. 字段 

字段 是 表 中 的 一 列 , 在 一 般 情况 下 ,字段 和 列 所 指 的 内 容 是 相同 的 。 在 表 12. 1 中 ,“ 学 号 ” 
列 就 是 一 个 字段 。 

4. 关系 

关系 是 一 个 从 数学 中 而 来 的 概念 ,在 关系 代数 中 ,关系 是 指 二 维 表 , 表 既 可 以 用 来 表示 数 
据 ,也 可 以 用 来 表示 数据 之 间 的 联系 。 

在 数据 库 中 ,关系 是 建立 在 两 个 表 之 间 的 链接 ,以 表 的 形式 表示 其 间 的 链接 ,使 数据 的 处 
理 和 表达 有 更 大 的 灵活 性 。 关 系 有 3 种 , 即 一 对 一 关系 、 一 对 多 关系 和 多 对 多 关系 。 

5. 索引 

索引 是 建立 在 表 上 的 单独 的 物理 数据 库 结构 ,基于 索引 的 查询 使 数据 获取 更 为 快捷 。 索 
引 是 表 中 的 一 个 或 多 个 字段 ,索引 可 以 是 唯一 的 ,也 可 以 是 不 唯一 的 ,主要 看 这 些 字段 是 否 允 
许 重复 。 主 索引 是 表 中 的 一 列 和 多 列 的 组 合 ,作为 表 中 记录 的 唯一 标识 。 外 部 索引 是 相关 联 
的 表 的 一 列 或 多 列 的 组 合 , 通 过 这 种 方式 来 建立 多 个 表 之 间 的 联系 。 

6. 视图 

视图 是 一 个 与 真实 表 相 同 的 虚拟 表 , 用 于 限制 用 户 可 以 看 到 和 修改 的 数据 量 ,从 而 简化 数 
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据 的 表达 。 

7. 存储 过 程 

存储 过 程 是 一 个 编译 过 的 SQL 程序 。 在 该 过 程 中 可 以 嵌入 条 件 罗 辑 、 传 递 参 数 、 定 义 变 
量 和 执行 其 他 编程 任务 。 


12.1.2 SOL Server 2012 数据 库 管理 系统 


SQL Server 2012 是 Microsoft 公司 在 SQL Server 2008 基础 上 推出 的 关系 数据 库 管 理 系 
统 ,是 目前 主流 的 数据 库 管理 系统 之 一 。SQL Server 2012 Express 是 一 个 轻 量 级 的 免费 
版 本 。 

1. 建立 数据 库 Stud 

在 安装 SQL Server 2012 Express 并 进入 SQL Server 系统 后 (这 里 的 登录 名 为 sa, 密 码 为 
12345) ,通过 右 击 “数据 库 ” 结 点 ,在 出 现 的 快捷 菜单 中 选择 “新 建 数 据 库 ”命令 ,建立 一 个 名 称 
为 Stud 的 数据 库 , 将 其 路 径 改 为 *“D:\ASP.NET\ch12” 网 站 的 App_Data 目录 ,这 样 会 自动 建 
立 Stud. mdf 和 Stud_log. ldf 两 个 文件 ,前 者 为 数据 库 主 文件 ,后 者 是 日 志文 件 。 

重要 操作 : 使 用 Visual Studio 2012 创建 一 个 对 应 "*D:\ASP.NET\ch12” 目 录 的 ch1l2 空 
网 站 ,在 解决 方案 资源 管理 器 中 右 击 项 目 名 ch12, 在 出 现 的 快捷 菜单 中 选择 “添加 | 添加 ASP. 
NET 文件 夹 |App_Data” 命 令 , 创 建 一 个 App_Data 目录 ,将 Stud 数据 库 的 文件 存放 在 其 中 。 
另外 ,将 第 9 章 创建 的 主题 目录 App_Themes 复制 到 ch12 网 站 中 ,以 便于 本 章 的 网 页 布局 ， 
在 复制 后 右 击 项 目 名 ch12, 在 出 现 的 快捷 菜单 中 选择 “刷新 目录 ”命令 即 可 看 到 App_Themes 
目录 。 

2. 建立 数据 表 student 和 score 

再 展开 Stud 数据 库 , 右 击 下方 的 “ 表 ? 项 ,在 出 现 的 快捷 菜单 中 选择 “新 建 表 ”命令 ,可 以 通 
过 交互 建立 表 结 构 。 这 里 新 建 student 和 score 两 个 表 , 前 者 的 关键 字 为 “学 号 ”, 后 者 的 关键 
字 为 “学 号 十 课程 名 ”, 它 们 的 表 结 构 分 别 如 图 12. 1 和 图 12. 2 所 示 。 


LCB-PO\SQLEXPRE.ud - dbo.student Xx 


列 各 数据 类 型 允许 Null 值 
网 char(5) 加 
姓名 char(10) 国 列 名 数据 类型 允许 Null 值 
性 别 char(2) 国 由 辐 char(5) 
民族 char(10) 国 时 课程 名 charl16) 回 
班 号 char(10) 贺 分 数 float 加 
固 
图 12.1 student 表 结 构 图 12.2 score 表 结 构 


在 Stud 数据 库 的 表 项 下 方 出 现 db. student 和 dbo. score 两 个 表 项 ,选中 student 表 , 右 击 
鼠标 ,在 出 现 的 快捷 菜单 中 选择 “编辑 前 200 行 ” 命 令 , 可 以 输入 表 记 录 。 在 student 和 score 
表 中 输入 的 记录 分 别 如 图 12. 3 和 图 12.4 所 示 ( 分 别 对 应 表 12. 1 和 表 12. 2 中 的 记录 )。 本 章 
后 面 的 例子 使 用 这 些 样 本 数据 介绍 数据 库 编 程 方法 。 

3. 权限 设置 

为 了 在 网 页 中 访问 Stud 数据 库 ,必须 给 Stud 数据 库 设置 一 些 访问 权限 ,否则 在 网 页 运行 
时 会 出 现 无 法 打开 Stud 数据 库 的 登录 失败 错误 。 
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LCB-POSQLEXPRE...Stud - dbo.score x 


学 号 课程 名 分 数 
» 国 CE 去 80 
1 数据 结构 87 
2 语言 70 
2 数据 结构 52 
_ 性别 3 < 语言 89 
女 3 数据 结构 84 
女 6 C5 言 90 
男 6 数据 结构 95 
男 8 CE 言 88 
黑 8 数据 结构 36 
|NULL NULL NULL NULL NULL # NUL NU NU 
图 12.3 student 表 记 录 图 12.4 score 表 记 录 


给 Stud 数据 库 设 置 一 些 公共 用 户 访问 权限 的 操作 如 下 : 

@ 布 击 “ 数 据 库 ” 结 点 的 "Stud” 数 据 库 ,在 出 现 的 快捷 菜单 中 选择 “属性 ”命令 ,在 出 现 的 
“数据 库 属 性 -Stud” 对 话 框 中 单 击 “权限 ?项 ,此 时 全 为 空白 项 ,说 明 没 有 授予 任何 权限 。 

@ 单 击 “ 搜 索 ” 按 钮 ,在 出 现 的 “选择 用 户 或 角色 ”对 话 框 中 单 击 “ 浏 览 ” 按 钮 。 

@ 在 出 现 的 对 话 框 中 色 选 “Lpublicj” 项 ,返回 到 “数据 库 属性 -Stud” 对 话 框 。 

@ 通过 勾 选 *public 的 权限 ”的 显 式 列表 中 的 “插入 ”“ 删 除 ”、“ 更 改 *" 和 “选择 ”等 授予 项 
以 授予 相应 权限 ,如 图 12.5 所 示 。 


Sn | 
| 


加 ?| 


查看 数据 库 状态 


回回 回回 回回 
回回 回回 回回 


创建 zl 架构 集合 


[< 


1 


图 12.5 “数据 库 属性 -Stud” 对 话 框 
这 样 便 可 以 在 网 页 中 访问 Stud 数据 库 了 。 
12.1.3 结构 化 查询 语言 
结构 化 查询 语言 (SQL) 是 目前 各 种 关系 数据 库 管理 系统 广泛 采用 的 数据 库 语 言 ,很 多 数 


295 
第 12 章 ADO.NET 数据 库 访 问 技 


据 库 和 软件 系统 都 支持 SQL 或 提供 SQL 语言 接口 。 本 节 在 SQL Server 2012 数据 库 管 理 系 
统 中 介绍 SQL 语句 的 使 用 。 
1. SQL 语言 的 组 成 
SQL 语言 包含 查询 .操纵 .定义 和 控制 等 几 个 部 分 。 它 们 都 是 通过 命令 动词 分 开 的 ,各 种 
语句 类 型 对 应 的 命令 动词 如 下 : 
。 数据 查询 的 命令 动词 为 SELECT。 
。 数据 定义 的 命令 动词 为 CREATE、DROP。 
。 数据 操纵 的 命令 动词 为 INSERT、UPDATE、DELETE。 
。 数据 控制 的 命令 动词 为 GRANT、REVOKE。 
2. 数据 定义 语言 
(1) CREATE 语句 
CREATE 语句 用 于 建立 数据 表 , 其 基本 格式 如 下 : 
CREATE TABLE 表 名 
( 列 名 1 数据 类 型 1 [NOT NULL] 
[, 列 名 2 数据 类 型 2 [NOT NULL]] …) 
【 例 12.1】 给 出 建立 一 个 学 生 表 student 的 SQL 语句 。 
解 : 对 应 的 SQL 语句 如 下 。 
CREATE TABLE student 
( 学 号 CHAR(5)， 
姓名 CHAR(10)， 
性 别 ChAR(2)， 
民族 CHAR(10)， 
班 号 CHAR(6)) 
(2) DROP 语句 
DROP 语句 用 于 删除 数据 表 , 其 基本 格式 如 下 : 
DROP TABLE 表 名 
3. 数据 操纵 语言 
(1) INSERT 语句 
INSERT 语句 用 于 在 一 个 表 中 添加 新 记录 ,然后 给 新 记录 的 字段 赋值 ,其 基本 格式 如 下 ， 
INSERT INTO 表 名 [( 列 名 1[, 列 名 2，…])] 
VALUES( 表 达 式 1[ ,表达 式 2，…]) 
【 例 12.2】 给 出 向 score 表 中 插入 表 12. 2 所 示 记 录 的 SQL 语句 。 
解 : 对 应 的 SQL 语句 如 下 。 
INSERT INTO score( 学 号 ,课程 名 ,分 数 ) VALUES( '1', 'C 语 言 ',80) 
INSERT INTO score( 学 号 ,课程 名 ,分 数 ) VALUES('1', ' 数 据 结构 ',87) 
INSERT INTO score( 学 号 ,课程 名 , 分数) VALUES( '2', 'C 语言 ',70) 
INSERT INTO score( 学 号 ,课程 名 ,分 数 ) VALUES( '2', ' 数 据 结构 ', 52) 
INSERT INTO score( 学 号 ,课程 名 , 分数) VALUES( '3', 'C 语言 ',89) 
INSERT INTO score( 学 号 ,课程 名 ,分 数 ) VALUES( '3', ' 数 据 结构 ,84) 
INSERT INTO score( 学 号 ,课程 名 , 分数) VALUES( '6', 'C 语言 ',90) 
INSERT INTO score( 学 号 ,课程 名 ,分 数 ) VALUES( '6', ' 数 据 结构 ,95) 
INSERT INTO score( 学 号 ,课程 名 ,分 数 ) VALUES( '8', 'C 语言 ,88) 
INSERT INTO score( 学 号 ,课程 名 , 分数) VALUES( '8', ' 数 据 结构 ',86) 
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(2) UPDATE 语句 

UPDATE 语句 用 于 以 新 的 值 更 新 表 中 的 记录 ,其 基本 格式 如 下 : 

UPDATE 表 名 

SET 列 名 1 = 表达 式 1 
[,SET 列 名 2 = 表达 式 2]… 

WHERE 条 件 表达 式 

(3) DELETE 语句 

DELETE 语句 用 于 删除 记录 ,其 基本 格式 如 下 : 

DELETE FROM 表 名 

[WHERE 条 件 表 达 式 ] 

4. 数据 查询 语句 

SQL 的 数据 查询 语句 是 使 用 很 频繁 的 语句 。SELECT 的 基本 格式 如 下 : 

SELECT 字段 表 

FORM 表 名 

WHERE 查询 条 件 

GROUP BY 分 组 字段 

HAVING 分 组 条 件 

ORDER BY 字段 [ASC|DESC] 

各 子 句 的 功能 如 下 。 

。 SELECT: 指定 要 查询 的 内 容 。 

。 FORM: 指定 从 其 中 选 定 记录 的 表 名 。 

。 WHERE: 指定 所 选 记 录 必 须 满足 的 条 件 。 

。 GROUP BY: 把 选 定 的 记录 分 成 特定 的 组 。 

。 HAVING: 说 明 每 个 组 需要 满足 的 条 件 。 

。 ORDER BY: 按 特 定 的 次 序 将 记录 排序 。 

其 中 ,在 “字段 表 ” 中 可 使 用 聚合 函数 对 记录 进行 合计 , 它 返 回 一 组 记录 的 单一 值 ,可 以 使 
用 的 聚合 函数 如 表 12. 3 所 示 。“ 查 询 条 件 ” 由 常量 .字段 名 .逻辑 运算 符 、 关 系 运算 符 等 组 成 ， 
其 中 的 关系 运算 符 如 表 12.4 所 示 。 


表 12.3 SQL 的 聚合 函数 及 其 说 明 


聚合 函数 说 明 聚合 函数 说 明 

AVG 返回 特定 字段 中 值 的 平均 数 MAX 返回 特定 字段 中 的 最 大 值 
COUNT 返回 选 定 记录 的 个 数 MIN 返回 特定 字段 中 的 最 小 值 
SUM 返回 特定 字段 中 所 有 值 的 总 和 


表 12.4 关系 运算 符 及 其 说 明 


关系 运算 符 说 明 关系 运算 符 说 明 
< 水手 <> 不 等 于 
二 一 小 于 等 于 BETWEEN 值 1AND 值 2 在 两 数值 之 间 
% 大 于 IN (一 组 值 ) 在 一 组 值 中 
>= 大 于 等 于 LIKE* 与 一 个 通配符 匹配 


* 通配符 可 使 用 “?" 代 表 一 个 字符 位 ,“%" 代 表 零 个 或 多 个 字符 位 。 
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对 于 前 面 建立 的 student 表 ( 它 包含 表 12. 1 中 的 记录 ) 和 score 表 完 成 以 下 各 例题 。 
【 例 12.3】〗 查询 student 表 中 的 所 有 学 生 记 录 。 

解 : 对 应 的 SQL 语句 如 下 。 

SELECT x FROM student 

其 运行 结果 如 图 12. 6 所 示 。 

【 例 12.4】 查询 student 表 中 “09002” 班 的 所 有 学 生 记 录 。 

解 : 对 应 的 SQL 语句 如 下 。 


SELECT * FROM student WHERE 班 号 = '09002' 


其 运行 结果 如 图 12.7 所 示 。 


国 结果 [Es 和 | 

学 号 姓名 性 别 民族 班 呈 
1 | 上 ] 玫 华 女 汉族 09001 
2 2 孙 南 女 汉族 09002 国 结果 | 消息 | 
3 3 李兵 男 满族 09001 学 号 姓名 性 别 民族 班 号 
4 “6 张 军 男 汉族 09001 1 [2 | 和 而 女 汉族 09002 
5 8 3 展 男 回族 0g002 2 8 3 棋 男 国 族 og002 
图 12.6 例 12.3 运行 结果 图 12.7 例 12.4 运行 结果 


【 例 12.5】 查询 所 有 学 生 的 学 号 、 姓 名、 课程 名 和 分 数 。 
解 : 对 应 的 SQL 语句 如 下 。 


SELECT student. 学 号 , student. 姓名 , score. 课程 名 , score. 分 数 

FROM student, score 

WHERE student. 学 号 = score. 学 号 

其 运行 结果 如 图 12. 8 所 示 。 

【 例 12.6】 查询 所 有 学 生 的 学 号 、 姓 名 、 课 程 名 和 分 数 , 要 求 按 课 程 名 排序 。 
解 : 对 应 的 SQL 语句 如 下 。 

SELECT student. 学 号 , student. 姓名 , score. 课程 名 , score. 分 数 

FROM student, score 


WHERE student. 学 号 = score. 学 号 
ORDER BY score. 课程 名 


其 运行 结果 如 图 12. 9 所 示 。 


EELIEET] 日 结果 [E 消 息 ] 
课程 名 。 分 数 学 号 姓名 课程 名 分数 
c 滞 言 8 1 人 | 于 华 c 语 言 。 80 
数据 结构 “87 2 孙 丽 Cc 语言 TD 
[语言 70 3 3 李兵 “语言 6 
数据 结构 52 4 56 张 备 c 滞 言 9 
兵 [语言 89 5 8 绒 Cc 语 言 98 
数据 结构 84 6 8 马 殿 堵 据 结构 56 
语言 ”90 7 “6 ” 张 曙 数据 结构 5 
数据 结构 95 8 ”3 李兵 数据 结构 84 
语言 ”88 9 ”2 孙 丽 数据 结构 52 
数据 结构 “66 10 ”1 王 华 孝 据 结构 87 
图 12.8 例 12.5 运行 结果 图 12.9 例 12.6 运行 结果 
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【 例 12.7】 查询 分 数 在 80 一 90 的 所 有 学 生 的 学 号 、 姓 名 、 课 程 名 和 分 数 。 
解 : 对 应 的 SQL 语句 如 下 。 

SELECT student. 学 号 , student. 姓名 , score. 课程 名 , score. 分数 
FROM student, score 

WHERE student. 学 号 = score. 学 号 AND score. 分 数 BETWEEN 80 AND 90 
其 运行 结果 如 图 12. 10 所 示 。 

【 例 12.8】 查询 每 个 班 每 门 课 程 的 平均 分 。 

解 : 对 应 的 SQL 语句 如 下 。 

SELECT student. 班 号 , score. 课程 名 ,AVG( score. 分 数 ) AS ' 平 均 分 ' 
FROM student, score 

WHERE student. 学 号 = score. 学 号 

GROUP BY student. 班 号 , score. 课程 名 

其 运行 结果 如 图 12. 11 所 示 。 

【 例 12.9】 查询 最 高 分 的 学 生 姓名 和 班 号 。 

解 : 对 应 的 SQL 语句 如 下 。 

SELECT student. 姓名 , student. 班 号 


FROM student, score 
WHERE student. 学 号 = score. 学 号 AND score. 分 数 = (SELECT MAX( 分 数 ) FROM score) 


其 运行 结果 如 图 12. 12 所 示 。 


国 结果 ai 息 | 
学 号 姓名 课程 名 。 分 数 
1 人 | 王 毕 co 语 言 。 
2 ”1 王 华 数据 结构 87 | 国 结 果 
3 3 李兵 c 潭 言 89 班 号 ”课程 名 。 平均 分 
4 ”3 李兵 数据 结构 84 1 jose! | c 潭 言 。。 98.3933339933333 
5 6 张 苗 c 闸 言 9 2 09002 Ci 语 高 79 国 细 逻 
8 6 3 棋 o 泗 言 6 | 3 oaool 款 据 结构 89.6688868666687 姓名 ”下 
了 日 马 梢 ” 教 据 结构 86 4 09002 ”数据 结构 69 1 味 守 oo00: 
图 12.10 例 12.7 运行 结果 图 12.11 例 12.8 运行 结果 图 12.12 例 12.9 运行 结 


12.2 ADO.NET 模型 


12.2.1 ADO .NET 简介 


在 SQL Server 系统 中 访问 自己 创建 的 数据 库 是 十 分 方便 的 ,但 是 如 何 从 外 部 访问 SQL 
Server 数据 库 呢 ? 为 此 人 们 提出 了 各 种 数据 库 的 访问 模型 ,ADO.NET 是 microsoft 公司 的 
新 一 代 .NET 数据 库 访 问 模型 , 它 是 目前 数据 库 程序 设计 师 用 来 开发 数据 库 应 用 程序 的 主要 
接口 。 

ADO.NET 是 在 .NET Framework 上 访问 数据 库 的 一 组 类 库 , 它 利用 .NET Data 
Provider( 数 据 提供 程序 ) 进 行 数据 库 的 连接 与 访问 ,通过 ADO.NET 数据 库 程 序 设 计 人 员 能 
够 很 轻易 地 使 用 各 种 对 象 来 访问 符合 自己 需求 的 数据 库 内 容 。 换 句 话 说 ,ADO. NET 定义 了 
一 个 数据 库 访问 的 标准 接口 ,让 提供 数据 库 管理 系统 的 各 个 厂商 可 以 根据 此 标准 开发 对 应 的 
.NET Data Provider, 这 样 编写 数据 库 应 用 程序 的 人 员 不 必 了 解 各 类 数据 库 底层 运作 的 细节 ， 
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只 要 学 会 ADO.NET 所 提供 对 象 的 模型 , 便 可 轻易 地 访问 所 有 支持 .NET Data Provider 的 数 


ADO.NET 是 应 用 程序 和 数据 源 之 间 沟 通 的 “桥梁 ”。 通 过 ADO.NET 所 提供 的 对 象 ,再 
配合 SQL 语句 就 可 以 访问 数据 库 中 的 数据 ,而 且 凡 是 能 通过 ODBC 或 OLEDB 接口 访问 的 数 
据 库 (如 dBase、FoxPro、Excel、Access、SQL Server 和 Oracle 等 ) 也 可 通过 ADO .NET 来 
访问 。 

ADO.NET 可 提高 数据 库 的 扩展 性 。ADO.NET 可 以 将 数据 库 中 的 数据 以 XML 格式 传 
送 到 客户 端 (Client) 的 DataSet 对 象 中 ,此 时 客户 端 可 以 和 数据 库 服务 器 端 离线 , 当 客户 端 程 
序 对 数据 进行 新 建 \ 修 改 、 删 除 等 操作 后 ,再 和 数据 库 服务 器 联机 ,将 数据 送 回 数据 库 服 务 器 端 
完成 更 新 的 操作 。 如 此 一 来 ,就 可 以 避免 客户 端 和 数据 库 服务 器 联机 时 虽然 客户 端 不 对 数据 
库 服务 器 做 任何 操作 却 一 直 占 用 数据 库 服务 器 的 资源 。 此 种 模型 使 得 数据 处 理由 相互 连接 的 
双 层 架构 向 多 层 式 架构 发 展 , 因 而 提高 了 数据 库 的 扩展 性 。 

使 用 ADO.NET 处 理 的 数据 可 以 通过 HTTP 来 传输 。 在 ADO.NET 模型 中 特别 针对 分 
布 式 数据 访问 提出 了 多 项 改进 ,为 了 适应 互联 网 上 的 数据 交换 ,ADO.NET 不 论 是 内 部 运作 
还 是 与 外 部 数据 交换 的 格式 都 采用 XML 格式 ,因此 能 很 轻易 地 直接 通过 HTTP 来 传输 数 
据 , 而 不 必 担 心 防火 墙 的 问题 , 而且 对 于 异 质 性 (不 同类 型 ) 数 据 库 的 集成 也 提供 最 直接 的 
支持 。 


12.2.2 ADO .NET 体系 结构 


ADO.NET 模型 主要 希望 在 处 理 数据 的 同时 不 要 一 直 和 数据 库 联 机 而 发 生 一 直 占用 系 
统 资源 的 现象 。 为 了 解决 此 问题 ,ADO.NET 将 访问 数据 和 数据 处 理 的 部 分 分 开 , 以 达到 离 
线 访 问 数据 的 目的 ,使 得 数据 库 能 够 运行 其 他 工作 。 

ADO.NET 模型 分 成 .NET Data Provider( 数 据 提供 程序 ) 和 DataSet 数据 集 ( 数 据 处 理 
的 核心 ) 两 大 主要 部 分 ,其 中 包含 的 主要 组 件 及 其 关系 如 图 12. 13 所 示 。 


TS 基 i 
.NET Framework 数 据 提供 程序 DataSet 
Connection DataAdapter 数据 表 
selecommand 
[Ca |] 
Command 


UpdateCommand ConstrainCollection 
Re DataRelationCollection 
[Deane | 


XML 


图 12.13 ADO.NET 组 件 结构 模型 
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1. .NET Data Provider 
.NET Data Provider 用 于 连接 到 数据 库 ,执行 命令 和 检索 结果 ,可 以 直接 处 理 检索 到 的 
结果 ,或 将 其 放 入 ADO.NET DataSet 对 象 ,以 便 与 来 自 多 个 源 的 数据 或 在 层 之 间 进 行 远程 
处 理 的 数据 组 合 在 一 起 ,以 特殊 方式 向 用 户 公 开 。. NET Framework 数据 提供 程序 是 轻 量 
的 , 它 在 数据 源 和 代码 之 间 创建 了 一 个 最 小 层 , 以 便 在 不 以 牺牲 功能 为 代价 的 前 提 下 提高 
性 能 。 
表 12.5 给 出 了 .NET Data Provider 中 包含 的 4 个 核心 对 象 。 
表 12.5 .NET Data Provider 中 包含 的 4 个 核心 对 象 及 其 说 明 
对 象 名 称 功能 说 明 
Connection ”提供 和 数据 源 的 连接 功能 
Command 提供 运行 访问 数据 库 命令 ,传送 数据 或 修改 数据 的 功能 ,例如 运行 SQL 命令 和 存储 过 程 等 
DataAdapter DataSet 对象 和 数据 源 间 的 “桥梁 ”。DataAdapter 使 用 4 个 Command 对 象 来 运行 查询 、 新 
建 .修改 .删除 的 SQL 命令 ,把 数据 加 载 到 DataSet, 或 者 把 DataSet 内 的 数据 送 回 数据 源 
DataReader ”通过 Command 对 象 运行 SQL 查询 命令 取得 数据 流 ,以 便 进 行 高 速 . 只 读 的 数据 浏览 


通过 Connection 对 象 可 与 指定 的 数据 库 进行 连接 ;: Command 对 象 用 来 运行 相关 的 SQL 
命令 (如 SELECT INSERT UPDATE 或 DELETE) ,以 读 取 或 修改 数据 库 中 的 数据 。 通 过 
DataAdapter 对 象 中 所 提供 的 4 个 Command 对 象 进行 离线 式 的 数据 访问 ,这 4 个 Command 
对 象 分 别 为 SelectCommand 、InsertCommand、UpdateCommand 和 DeleteCommand, 其 中 
SelectCommand 是 用 来 将 数据 库 中 的 数据 读 出 并 放 到 DataSet 对 象 中 ,以 便 进 行 离 线 式 的 数 
据 访 问 ,至 于 其 他 3 个 命令 对 象 (InsertCommand UpdateCommand 和 DeleteCommand) 则 
是 用 来 修改 DataSet 中 的 数据 ,并 写 回 数据 库 中 ; 通过 DataAdapter 对 象 的 Fil 方法 可 以 
将 数据 读 到 DataSet 中 ; 通过 Update 方 法 则 可 以 将 DataSet 对 象 的 数据 更 新 到 指定 的 数 
据 库 中 。 

在 使 用 程序 管理 数据 库 之 前 ,要 先 确定 使 用 哪个 数据 提供 程序 来 访问 数据 库 , 数 据 提供 程 
序 就 是 一 组 用 来 访问 数据 库 的 对 象 , 常 用 的 数据 提供 程序 如 下 。 

(1) SQL.NET Data Provider 

支持 SQL Server 7.0 及 以 上 版 本 ,由 于 它 使 用 自己 的 通信 协议 并 且 做 过 最 优化 ,所 以 可 
以 直接 访问 SQL Server 数据 库 ,而 不 必 使 用 OLEDB 或 ODBC( 开 放 式 数据 库 连 接 层 ) 接 口 ， 
因此 效果 较 佳 。 若 程序 中 使 用 SQL.NET Data Provider, 则 在 该 ADO.NET 对 象 名 称 之 前 都 
要 加 上 Sql, 如 SqlConnection、SqlCommand、SqlDataReader 和 SqlDataAdapter 等 。 

在 所 有 使 用 SQL.NET Data Provider 的 网 页 中 ,其 引用 部 分 应 添加 using System. Data. 
SqlClient 语句 。 

(2) OLEDB.NET Data Provider 

支持 通过 OLEDB 接口 来 访问 dBase、FoxPro、Excel 和 Access 等 类 型 数据 源 。 在 程序 中 若 使 
用 OLEDB.NET Data Provider,ADO.NET 对 象 名 称 之 前 要 加 上 OleDb, 如 OleDbConnection、 
OleDbCommand ,OleDbDataReader 和 OleDbDataAdapter 等 。 

在 所 有 使 用 OLEDB.NET Data Provider 的 网 页 中 ,其 引用 部 分 应 添加 using System. 
Data. OleDb 语句 。 

SQL.NET Data Provider 使 用 它 自身 的 协议 与 SQL Server 通信 ,由 于 它 经 过 了 优化 ,可 
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以 直接 访问 SQL Server 而 不 用 添加 OLE DB 或 开放 式 数 据 库 连接 (ODBC) 层 ,因此 它 是 轻 量 
的 ,并 具有 良好 的 性 能 。 

(3) ODBC. NET Data Provider 

支持 通过 ODBC 接口 来 访问 dBase、FoxPro、Excel、Access、Oracle 以 及 SQL Server 等 类 
型 数据 源 。 在 程序 中 若 使 用 ODBC .NET Data Provider, ADO. NET 对 象 名 称 之 前 要 加 上 
Odbc, 如 OdbcConnection、OdbcCommand、OdbcDataReader 和 OdbcDataAdapter 等 。 

在 所 有 使 用 OLEDB. NET Data Provider 的 网 页 中 ,其 引用 部 分 应 添加 using System. 
Data. Odbc 语句 。 

(4) ORACLE. NET Data Provider 

支持 通过 ORACLE 接口 来 访问 ORACLE 数据 源 。 在 程序 中 若 使 用 ORACLE .NET 
Data Provider, ADO. NET 对 象 名 称 之 前 要 加 上 Oracle, 如 OracleConnection、OracleCommand、 
OracleDataReader 和 OracleDataAdapter 等 。 

在 所 有 使 用 OLEDB.NET Data Provider 的 网 页 中 ,其 引用 部 分 应 添加 using System. 
Data. OracleClient 语句 。 

从 以 上 介绍 看 到 ,为 了 访问 SQL Server 数据 库 , 可 以 使 用 SQL .NET Data Provider 和 
ODBC.NET Data Provider, 但 前 者 可 以 直接 访问 SQL Server 数据 库 , 若 使 用 后 者 ,还 需 建 立 
SQL Server 数据 库 对 应 的 ODBC 数据 源 。 本 章 主 要 介绍 使 用 SQL .NET Data Provide 直接 
访问 SQL Server 数据 库 的 方法 。 

2. DataSet 对 象 

DataSet( 数 据 集 ) 是 ADO.NET 离线 数据 访问 模型 中 的 核心 对 象 ,主要 使 用 时 机 是 在 内 
存 中 暂 存 并 处 理 各 种 从 数据 源 中 所 取 回 的 数据 。DataSet 其 实 就 是 一 个 存放 在 内 存 中 的 数据 
暂 存 区 ,这 些 数据 必须 通过 DataAdapter 对 象 与 数据 库 进 行 数据 交换 。 在 DataSet 内 部 允许 
同时 存放 一 个 或 多 个 不 同 的 数据 表 (DataTable) 对象。 这 些 数据 表 是 由 数据 列 和 数据 域 组 成 
的 ,并 包含 有 主 索 引 键 ,外 部 索引 键 、 数 据 表 间 的 关系 (Relation) 信 息 以 及 数据 格式 的 条 件 限 
制 (Constraint)。 

DataSet 的 作用 像 内 存 中 的 数据 库 管理 系统 ,因此 在 离线 时 DataSet 也 能 独自 完成 数据 的 
新 建 , 修 改 、 删 除 、 查 询 等 操作 ,而 不 必 一 直 局 限 在 和 数据 库 联机 时 才能 做 数据 维护 的 工作 。 
DataSet 可 以 用 于 访问 多 个 不 同 的 数据 源 、XML 数据 或 者 作为 应 用 程序 暂 存 系统 状态 的 暂 
存 区 。 

数据 库 通 过 Connection 对 象 连接 后 便 可 以 通过 Command 对 象 将 SQL 语法 (如 
INSERT、UPDATE、DELETE 或 SELECT) 交 由 数据 库 引 擎 (例如 SQL Server) 运 行 ,并 通过 
DataAdapter 对 象 将 数据 查询 的 结果 存放 到 离线 的 DataSet 对 象 中 ,进行 离线 数据 修改 ,对 降 
低 数 据 库 联机 负担 具有 极 大 的 帮助 。 至 于 数据 查询 部 分 .还 通过 Command 对 象 设置 
SELECT 查询 语法 和 通过 Connection 对 象 设置 数据 库 连 接 , 运 行 数据 查询 后 利用 DataReader 
对 象 以 只 读 的 方式 逐 笔 从 前 向 后 浏览 记录 。 


12.2.3 ADO .NET 数据 库 的 访问 流程 


ADO.NET 数据 库 访问 的 一 般 流程 如 下 : 
@ 建立 Connection 对 象 ,创建 一 个 数据 库 连 接 。 
@ 在 建立 连接 的 基础 上 可 以 使 用 Command 对 象 对 数据 库 发 送 查 询 、 新 增 、 修 改 和 删除 等 
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命令 。 
@ 创建 DataAdapter 对 象 ,从 数据 库 中 取得 数据 。 

@ 创建 DataSet 对 象 , 将 DataAdapter 对 象 填充 到 DataSet 对 象 (数据 集 ) 中 。 

@ 如 果 需 要 ,可 以 重复 操作 ,一 个 DataSet 对 象 可 以 容纳 多 个 数据 集合 。 

@ 关闭 数据 库 。 

@ 在 DataSet 上 进行 所 需要 的 操作 。 为 了 将 一 个 DataSet 数据 集 的 数据 输出 到 窗 体 中 或 
者 网 页 上 ,需要 设 定数 据 显示 控件 的 数据 源 为 该 数据 集 。 


12.3 ADO.NET 的 数据 访问 对 象 


ADO.NET 的 数据 访问 对 象 有 Connection、Command、DataReader 和 DataAdapter 等 。 
于 每 种 .NET Data Provider 都 有 自己 的 数据 访问 对 象 ,因此 它们 的 使 用 方式 相似 。 本 节 主 
要 介绍 SQL. NET Data Provider 的 各 种 数据 访问 对 象 的 使 用 ,所 有 这 些 数据 访问 对 象 都 位 于 
System. Data. SqlClient 命名 空间 中 。 


12.3.1 SqlConnection 对 象 


在 数据 访问 中 首先 必须 建立 数据 库 的 物理 连接 。SQL .NET Data Provider 使 用 
SqlConnection 类 对 象 来 实现 与 一 个 数据 库 的 物理 连接 。 

1. SqlConnection 类 

SqlConnection 类 的 常用 属性 如 表 12.6 所 示 。 


表 12.6 ”SqlConnection 类 的 常用 属性 及 其 说 明 


属 性 说 明 
ConnectionString 获取 或 设置 用 于 打开 数据 库 的 字符 串 
ConnectionTimeout 获取 在 尝试 建立 连接 时 终止 尝试 并 生成 错误 之 前 所 等 待 的 时 间 
Database 获取 当前 数据 库 或 连接 打开 后 要 使 用 的 数据 库 的 名 称 
DataSource 获取 数据 源 的 服务 器 名 或 文件 名 
Provider 获取 在 连接 字符 串 的 “Provider 二 ” 子 句 中 指定 的 SQL 提供 程序 的 名 称 
State 获取 连接 的 当前 状态 ,其 取 值 及 其 说 明 如 表 12.7 所 示 


表 12.7 State 枚 举 成 员 值 


成 员 名 称 说 明 
Broken 与 数据 源 的 连接 中 断 ,只 有 在 连接 打开 之 后 才 可 能 发 生 这 种 情况 ,可 以 关闭 处 于 这 
种 状态 的 连接 ,然后 重新 打开 
Closed 连接 处 于 关闭 状态 
Connecting 连接 对 象 正在 与 数据 源 连接 
Executing 连接 对 象 正在 执行 命令 
Fetching 连接 对 象 正在 检索 数据 


Open 连接 处 于 打开 状态 
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SqlConnection 类 的 常用 方法 如 表 12. 8 所 示 。 


表 12.8 SqlConnection 类 的 常用 方法 及 其 说 明 


海光 说 明 
Open 使 用 ConnectionString 所 指定 的 属性 设置 打开 数据 库 连 接 
Close 关闭 与 数据 库 的 连接 ,这 是 关闭 任何 打开 连接 的 首选 方法 
CreateCommand 创建 并 返回 一 个 与 SqlConnection 关联 的 SqlCommand 对 象 
ChangeDatabase 为 打开 的 SqlConnection 更 改 当 前 数据 库 
2. 建立 连接 字符 串 ConnectionString 


在 创建 一 个 SqlConnection 对 象 时 必须 设置 其 ConnectionString 属性 值 ,例如 ConnectionString 


属性 值 设置 如 下 : 


"Data Source = LCB - PC\ SQLEXPRESS; Initial Catalog = Stud; User ID = sa;Password = 12345" 


ConnectionString 中 常用 的 关键 字 值 的 有 效 名称 如 下 。 


Data Source: 指定 要 连接 的 SQL Server 实例 名 或 网 络 地 址 。 上 述 连 接 字符 串 中 的 
“LCB-PC\SQLEXPRESS” 就 是 SQL Server 的 一 个 实例 。 

Initial Catalog( 或 Database) : 指定 要 连接 的 数据 库 名 称 。 上 述 连接 字符 串 中 要 连接 
的 数据 库 为 Stud。 

Integrated Security( 或 Trusted_Connection) : 当 为 False( 默 认 值 ) 时 ,将 在 连接 中 指 
定 用 户 ID 和 密码 ; 当 为 True 时 ,将 使 用 当前 的 Windows 账户 凭据 进行 身份 验证 。 
其 可 识别 的 值 为 True、False、yes、no 以 及 与 True 等 效 的 sspi( 强 烈 推荐 ) 。 

Persist Security Info: 当 该 值 设 置 为 False( 默 认 值 ) 或 no( 强 烈 推荐 ) 时 ,如 果 连 接 是 打 
开 的 或 者 一 直 处 于 打开 状态 ,那么 安全 敏感 信息 (如 密码 ) 将 不 会 作为 连接 的 一 部 分 返 
回 。 重 置 连接 字符 串 将 重 置 包 括 密码 在 内 的 所 有 连接 字符 串 值 。 其 可 识别 的 值 为 
True,False、yes 和 no。 

User ID: 指定 SQL Server 的 登录 账户 。 

Password( 或 Pwd) : 指定 SQL Server 账户 登录 的 密码 。 


在 指定 连接 字符 串 后 ,最 后 用 Open 方法 打开 连接 。 
【 例 12. 10】 设计 一 个 采用 直接 建立 连接 字符 串 的 方法 实现 Stud 数据 库 连 接 的 网 页 
WebForml. aspx。 


解 : 


_ 
© 


: 其 步骤 如 下 。 
在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForml 空 网 页 。 
其 设计 界面 如 图 12. 14 所 示 ,其 中 包含 一 个 Button 控件 Buttonl 和 一 个 标签 Labell， 


将 该 网 页 的 StyleSheetTheme 属性 设置 为 Blue。 在 该 网 页 上 设计 如 下 事件 过 程 : 


usi 
pro 


{ 


ng System. Data. SqlClient; // 网 页 代码 页 新 增 的 引用 
tected void Buttonl_Click(object sender, EventArgs e) 

SqlConnection myconn = new SqlConnection(); 

string mystr = @"Data Source = LCB - PC\SQLEXPRESS; 

Initial Catalog = Stud;User ID = sa;Password = 12345"; 

myconn. ConnectionString = mystr; 

myconn. Open( ); 

if (myconn. State == System. Data. ConnectionState. Open) 

Labell.Text = "成 功 连 接 到 SQL Server 数据 库 "; 
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else 


Labell.Text = "不 能 连接 到 SQL Server 数据 库 "; 
myconn. Close( ); 


} 


@ 单 击 工具 栏 中 的 p> Imternet Explorer 按钮 运行 本 网 页 ,然后 单 击 “ 连 接 ” 命 令 按 钮 ,其 运行 结 
果 如 图 12. 15 所 示 , 表 示 成 功 连 接 到 Stud 数据 库 。 


一 
© 碟 htpy/localhost5115 PD-C 
@ localhost x 


i[Label1] cad 连接 


| = 成 功 连 接 到 SQL Server 数 据 库 
5 设计 |e 白 分 |。 源 | [人 P| 


图 12.14 WebForml 网 页 设计 界面 图 12.15 WebForml 网 页 运行 界面 


3. 将 连接 字符 串 存放 在 Web. config 文件 中 
用 户 可 以 在 Web. config 文件 中 保存 用 于 连接 数据 库 的 连接 字符 串 , 再 通过 对 Web. config 文 
件 加 密 , 从 而 达到 保护 连接 字符 串 的 目的 。 例 如 ,在 Web. config 文件 的 二 configuration 二 节 中 插 
入 以 下 代码 ， 
<“connectionStrings > 
<add name = "myconnstring" 
connectionString = "Data Source = LCB— PC\SQLEXPRESS; Initial Catalog = Stud; 
User ID= sa;Password = 12345" 


providerName = "System. Data. SqlClient" /> 
</connectionStrings > 


这 样 ,以 下 代码 自动 获取 Web. config 文件 中 的 连接 字符 串 myconnstring 并 打开 连接 : 
string mystr = System. Configuration.ConfigurationManager. 
ConnectionStrings["myconnstring"]. ToString( ); 
SqlConnection myconn = new SqlConnection(); 
myconn. ConnectionString = mystr; 
myconn. Open( ); 
说 明 : ConfigurationManager 类 位 于 System. Configuration 命名 空间 中 ,提供 对 客户 端 
应 用 程序 配置 文件 的 访问 。 其 中 ConnectionStrings 属性 用 于 获取 当前 应 用 程序 默认 配置 的 
ConnectionStrings 节 的 数据 。 后 面 的 示例 均 采 用 这 种 方法 。 
建立 的 数据 库 连接 在 使 用 完毕 后 必须 调用 Close 方法 关闭 它 ,为 了 避免 因为 忘记 使 用 
Close 方法 关闭 连接 而 造成 资源 浪费 ,可 以 使 用 using 语句 块 的 方法 建立 数据 库 连接 ,其 基本 
格式 如 下 : 
string mystr = System. Configuration.ConfigurationManager. 
ConnectionStrings["myconnstring" ]. ToString(); 
using (SqlConnection myconn = new SqlConnection()) 
{ myconn.ConnectionString = mystr; 
myconn. Open( ); 


} 
这 样 无 论 程 序 块 是 如 何 退 出 的 ,using 语句 都 会 自动 关闭 数据 库 连 接 。 
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12.3.2 SqlCommand 对 和 象 


在 建立 数据 连接 之 后 就 可 以 执行 数据 访问 操作 和 数据 操纵 操作 了 。 对 数据 库 的 操作 一 般 
被 概括 为 CRUD 一 一 Create、Read、Update 和 Delete, 在 ADO.NET 中 定义 SqlCommand 类 去 


执行 这 些 操 作 。 


1. SqlCommand 类 的 属性 和 方法 
SqlCommand 类 有 自己 的 属性 ,其 属性 包含 对 数据 库 执行 命令 所 需要 的 全 部 信息 ,通常 包 


括 以 下 内 容 。 


。 一 个 连接 : 命令 引用 一 个 连接 ,使 用 它 与 数据 库 通信 。 

。 命令 的 名 称 或 者 文本 : 包含 某 SQL 语句 的 实际 文本 或 者 要 执行 的 存储 过 程 的 名 称 。 

。 命令 类 型 : 指明 命令 的 类 型 ,如 命令 是 存储 过 程 还 是 普通 的 SQL 文本 。 

。 参数 : 命令 可 能 要 求 随 命令 传递 参数 ,命令 还 可 能 返回 值 或 者 通过 输出 参数 的 形式 返 
回 值 。 每 个 命令 都 有 一 个 参数 集合 ,可 以 分 别 设置 或 者 读 取 这 些 参数 以 传递 或 接 


受 值 。 


SqlCommand 类 的 常用 属性 如 表 12. 9 所 示 。 


属 性 


表 12.9 SqlCommand 类 的 常用 属性 及 其 说 明 
说 明 


CommandText 
CommandTimeout 
CommandType 
Connection 


Parameters 


成 员 名 称 


获取 或 设置 要 对 数据 源 执行 的 SQL 语句 或 存储 过 程 

获取 或 设置 在 终止 执行 命令 的 尝试 并 生成 错误 之 前 的 等 待 时 间 

获取 或 设置 一 个 值 ,该 值 指示 如 何 解释 CommandText 属性 ,其 取 值 如 表 12. 10 所 示 
获取 或 设置 SqlCommand 的 此 实例 使 用 的 SqlConnection 

参数 集合 (SqlParameterCollection) 


表 12. 10 ”CommandType 枚 举 成 员 值 
说 明 


StoredProcedure 


TableDirect 


Text 


CommandType 属性 应 设置 为 存储 过 程 的 名 称 。 如 果 存 储 过 程 名 称 包含 任何 特殊 字 
符 , 则 可 能 会 要 求 用 户 使 用 转 义 符 语法 。 当 调用 Execute 方法 之 一 时 ,该 命令 将 执行 
此 存储 过 程 

CommandType 属性 应 设置 为 要 访问 的 表 的 名 称 。 当 调用 Execute 方 法 之 一 时 ,将 返 
回 命名 表 的 所 有 行 和 列 

SQL 文本 命令 (默认 ) ,不 支持 在 向 通过 Text 的 CommandType 调用 的 SQL 语句 或 
存储 过 程 传递 参数 时 使 用 问号 (?) 占 位 符 , 在 这 种 情况 下 必须 使 用 命名 的 参数 


SqlCommand 类 的 常用 方法 如 表 12. 11 所 示 。 


方 ”法 


表 12.11 SqlCommand 类 的 常用 方法 及 其 说 明 
说 明 


CreateParameter 
ExecuteNonQuery 
ExecuteReader 


ExecuteScalar 


创建 SqlParameter 对 象 的 新 实例 

针对 Connection 执行 SQL 语句 并 返回 受 影响 的 行 数 

将 CommandText 发 送 到 Connection 并 生成 一 个 SqlDataReader 

执行 查询 .并 返回 查询 所 返回 的 结果 集中 第 一 行 的 第 一 列 ,忽略 其 他 列 或 行 
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2. 创建 SqlCommand 对 象 

SqlCommand 类 的 主要 构造 函数 如 下 : 

SqlCommand( ) ; 

SqlCommand( cmdText) 7 

SqlCommand( cmdText, connection) 

其 中 ,cmdText 参数 指定 查询 的 文本 。connection 参数 是 一 个 SqlConnection , 它 表 示 到 
SQL Server 数据 库 的 连接 。 例 如 ,以 下 语句 创建 一 个 SqlCommand 对 象 mycmd: 

string mystr = System. Configuration.ConfigurationManager. 

ConnectionStrings["myconnstring" ]. ToString(); 

myconn. ConnectionString = mystr; 

myconn. Open( ); 

SqlCommand mycmd = new SqlCommand("SELECT * FROM student",myconn); 

3. 通过 SqlCommand 对 象 返 回 单个 值 

在 SqlCommand 的 方法 中 ,ExecuteScalar 方法 执行 返回 单个 值 的 SQL 命令 。 例 如 ,如 果 
想 获取 Student 数据 库 中 学 生 的 总 人 数 , 则 可 以 使 用 这 个 方法 执行 SQL 查询 SELECT Count( * ) 
FROM student。 

【 例 12.11】 设计 一 个 通过 SqlCommand 对 象 求 score 表 中 的 所 有 学 生平 均 分 的 网 页 
WebForm2 。 

解 : 其 步骤 如 下 。 

@ 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm2 空 网 页 。 

@ 其 设计 界面 如 图 12. 16 所 示 , 其 中 包含 一 个 HTML 标签 ,一 个 文本 框 TextBoxl 和 一 
个 Button 控件 Button1。 在 该 网 页 上 设计 如 下 事件 过 程 : 

protected void Button1_Click(object sender, EventArgs e) 

{ stringmystr, mysql; 

SqlConnection myconn = new SqlConnection(); 

SqlCommand mycmd = new SqlCommand(); 

mystr = System.Configuration.ConfigurationManager. 
ConnectionStrings["myconnstring"]. ToString( ); 

myconn. ConnectionString = mystr; 

myconn. Open( ); 

mysql = "SELECT AVG( 分 数 ) FROM score"; 

mycmd. CommandText = mysql; 

mycmd. Connection = myconn; 

TextBoxl. Text = mycmd. ExecuteScalar().ToString(); 

myconn. Close( ); 

} 

说 明 : 将 本 网 页 的 StyleSheetTheme 属性 设置 为 Blue, 将 HTML 标签 的 class 设置 为 
StyleSheet. css 中 的 html-stylel 。 所 有 这 些 用 于 网 页 布局 的 皮肤 文件 和 CSS 文件 都 位 于 App_ 
Themes 目录 中 (从 第 9 章 复 制 而 来 )。 如 无 特别 说 明 , 后 面 的 示例 均 采 用 这 种 布局 设计 。 另 
外 ,所 有 网 页 代码 都 添加 “using System. Data. SqlClient;” 来 引用 System. Data. SqlClient 命名 
空间 。 

图 单 击 工具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 .然后 单 击 “ 求 平均 分 "命令 按钮 ,其 运 
行 结果 如 图 12. 17 所 示 .表示 所 有 学 生 的 平均 分 为 82. 1。 
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本 日 拆 分 |。 源 oy 


图 12.16 WebForm2 网 页 设计 界面 图 12.17 WebForm2 网 页 运行 界面 


4. 通过 SqlCommand 对 象 执行 修改 操作 
在 SqlCommand 的 方法 中 ,ExecuteNonQuery 方法 执行 不 返回 结果 的 SQL 命令 。 该 方 
法 主要 用 来 更 新 数据 ,通常 使 用 它 来 执行 UPDATE INSERT 和 DELETE 语句 。 该 方法 不 返 
回 行 ,对 于 UPDATE INSERT 和 DELETE 语句 ,返回 值 为 该 命令 所 影响 的 行 数 ; 对 于 所 有 
其 他 类 型 的 语句 ,返回 值 为 一 1。 


【 例 12. 12】 


的 网 页 WebForm3。 
解 : 其 步骤 如 下 。 
Oa 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm3 空 网 页 。 
@ 其 设计 界面 如 图 12. 18 所 示 , 其 中 包含 两 个 命令 按钮 控件 (Buttonl 和 Button2) 和 一 个 
标签 Labell 。 在 该 网 页 上 设计 如 下 事件 过 程 ， 


public partial class WebForm3 : System. Web.UI. Page 


{ 


} 


SqlCommand mycmd = new SqlCommand(); // 类 字段 
SqlConnection myconn = new SqlConnection(); // 类 字段 
protected void Page_Load(object sender, EventArgs e) 
{ string mystr = System. Configuration. ConfigurationManager. 
ConnectionStrings[ "myconnstring" ].ToString(); 
myconn. ConnectionString = mystr; 
myconn. Open(); 
} 
protected void Page_Unload( ) 
1 
myconn. Close( ); // 关 闭 本 网 页 时 关闭 连接 
} 
protected void Button1_Click(object sender, EventArgs e) 
{ ”string mysql = "UPDATE score SET 分 数 = 分 数 +5"; 
mycmd. CommandText = mysql; 
mycmd. Connection = myconn; 
mycmd. ExecuteNonQuery( ); 
Labell.Text = "所 有 学 生 分 数 均 增加 5 分 "; 
} 
protected void Button2_Click(object sender, EventArgs e) 
{ ”string mysql = "UPDATE score SET 分 数 = 分 数 一 5"; 
mycmd. CommandText = mysql; 
mycmd. Connection = myconn; 
mycmd. ExecuteNonQuery( ); 
Labell.Text =“ 所 有 学 生 分 数 均 减少 5 分 "; 


上 述 代 码 先 建立 连接 ,然后 通过 ExecuteNonQuery 方法 执行 SQL 命令 ,不 返回 任何 
果 , 在 关闭 网 页 时 关闭 连接 。 


设计 一 个 通过 SqlCommand 对 象 将 score 表 中 的 所 有 分 数 增 5 分 和 减 5 分 


疆 


二 
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@ 单 击 工具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,然后 单 击 “ 分 数 十 5” 命 令 按 钮 ,此 时 
score 表 中 的 所 有 分 数 都 增加 5 分 ,其 运行 界面 如 图 12. 19 所 示 。 为 了 保持 score 表 不 变 , 再 单 
击 “ 分 数 -5 ”命令 按钮 ,此 时 score 表 中 的 所 有 分 数 都 恢复 成 原来 的 数据 。 


Bs| [us 
| 所 有 学 生 分 数 均 增加 5 分 


» 
5 设 + |a 折 分 |。 源 | [|<body> 轩 


图 12.18 WebForm3 网 页 设计 界面 图 12.19 WebForm3 网 页 运行 界面 


5. 在 SqlCommand 对 象 的 命令 中 指定 参数 

SQL.NET Data Provider 支持 执行 命令 中 包含 参数 的 情况 ,也 就 是 说 ,可 以 使 用 包含 参数 
的 数据 命令 或 存储 过 程 执行 数据 筛选 操作 和 数据 更 新 等 操作 ,其 主要 流程 如 下 

@ 创建 Connection 对 象 .并 设置 相应 的 属性 值 。 

@ 打开 Connection 对 象 。 

G 创建 Command 对 象 并 设置 相应 的 属性 值 ,其 中 SQL 语句 参数 使 用 参数 名 称 。 

@ 创建 参数 对 象 ,将 建立 好 的 参数 对 象 添加 到 Command 对 象 的 Parameters 集合 中 。 

@ 为 参数 对 象 赋值 。 

@ 执行 数据 命令 。 

@ 关闭 相关 对 象 。 

例如 下 面 的 更 新 语句 : 


UPDATE course SET cName = @Name WHERE cID = @ID 


其 中 course 是 一 个 课程 表 , 有 cID( 课 程 号 ) 和 cName( 课 程 名 ) 两 个 列 。 该 命令 是 将 指定 
cID 的 课程 记录 的 cName 替换 成 指定 的 值 ,其 中 @ID 和 @Name 均 为 参数 ,在 执行 该 语句 之 
前 需要 为 参数 赋值 。 

那么 如 何 为 参数 赋值 呢 ? SqlCommand 对 象 的 Parameters 属性 能 够 取得 与 SqlCommand 
相关 联 的 参数 集合 (也 就 是 SqlParameterCollection) ,从 而 通过 调用 其 Add 方法 将 SQL 语句 
中 的 参数 添加 到 参数 集合 中 ,每 个 参数 都 是 一 个 SqlParameter 类 对 象 ,其 常用 属性 及 说 明 如 
表 12. 12 所 示 。 


表 12.12 SqlParameter 的 常用 属性 及 其 说 明 


属 性 说 明 
Parameter Name 用 于 指定 参数 的 名 称 
SqlDbType 用 于 指定 参数 的 数据 类 型 ,例如 整 型 .字符 型 等 
Value 设置 输入 参数 的 值 
Size 设置 数据 的 最 大 长 度 ( 以 字 节 为 单位 ) 
Scale 设置 小 数位 数 
Direction 指定 参数 的 方向 ,可 以 是 下 列 值 之 一 。ParameterDirection. Input: 指明 为 输入 参数 。 


了 ParameterDirection. Output: 指明 为 输出 参数 。ParameterDirection. InputOutput: 指明 
为 输入 参数 或 者 输出 参数 。ParameterDirection. ReturnValue: 指明 为 返回 值 类 型 
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例如 ,假设 mycmd 数据 命令 对 象 包含 前 面 带 参数 的 命令 ,可 以 使 用 以 下 命令 向 Parameters 
参数 集合 中 添加 参数 值 : 


mycmd. Parameters. Add( " @Name", SqlDbType. VarChar,10).Value = Namel; 
mycmd. Parameters. Add(" @ID", SqlDbType.VarChar,5).Value = ID1; 


上 面 Add 方法 中 的 第 1 个 参数 为 参数 名 ,第 2 个 参数 为 参数 的 数据 类 型 ,第 3 个 参数 为 
参数 值 的 最 大 长 度 , 并 分 别 将 参数 值 设置 为 Namel 和 ID1 变量 。 上 述 语句 也 可 以 等 价 地 
改 为 ， 


SqlParameter myparml = new SqlParameter(); 

myparml1.ParameterName = "@Name"; 

myparml. SqlDbType = System.Data. SqlDbType. VarChar; 

myparml.Size = 10; 

myparml. Value = Namel; // 设 置 参 数值 为 Namel 
mycmd. Parameters.Rdd(myparml) 

SqlParameter myparm2 = new SqlParameter(); 

myparm2. ParameterName = "@ID"; 

myparm2. SqlDbType = System.Data. SqlDbType. VarChar; 

myparm2. Size = 5; 

myparm2. Value = ID1; // 设 置 参 数值 为 ID1 
mycmd. Parameters. Add( myparm2); 


【 例 12.13】 设计 一 个 通过 SqlCommand 对 象 求 出 指定 学 号 的 学 生 的 平均 分 的 网 页 
WebForm4, 

解 : 其 步骤 如 下 。 

@ 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm4 空 网 页 。 

@ 其 设计 界面 如 图 12. 20 所 示 , 其 中 包含 两 个 HTML 标签 ,两 个 文本 框 (TextBoxl 和 
TextBox2) 和 一 个 Button 控件 Button1。 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Buttonl_Click(object sender, EventArgs e) 
SqlConnection myconn = new SqlConnection(); 
SqlCommand mycmd = new SqlCommand(); 
string mystr = System.Configuration.ConfigurationManager. 
ConnectionStrings[ "myconnstring" ].ToString(); 
myconn. ConnectionString = mystr; 
myconn. Open( ); 
string mysql = "SELECT AVG( 分 数 ) FROM score WHERE 学 号 = @no"; 
mycmd. CommandText = mysql; 
mycmd. Connection = myconn; 
mycmd. Parameters. Rdd("@no" ,System. Data. SqlDbType. VarChar, 5). Value = TextBox]. Text; 
TextBox2. Text = mycmd. ExecuteScalar().ToString(); 
myconn. Close( ); 


} 

上 述 代 码 先 建 立 连接 ,然后 通过 ExecuteScalar 方法 执行 SQL 命令 ,通过 “@no” 替 换 返 回 
指定 学 号 的 平均 分 。 

@ 单 击 工具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,输入 学 号 8, 单 击 “ 求 平均 分 "命令 按 
钮 ,运行 界面 如 图 12. 21 所 示 。 
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x 
WE OB ee p -ol OE 
学 号 : 平均 分 : 铺 localhost *| | 


| 他 


1 » 求 平均 分 
设计 | 拆 分 |。 源 | |[4] <asp:ButtonzButtora: 


图 12.20 WebForm4 网 页 设计 界面 图 12. 21 WebForm4 网 页 运行 界面 


12.3.3 SqlDataReader 对 象 


当 执行 返回 结果 集 的 命令 时 ,需要 一 个 方法 从 结果 集中 提取 数据 。 处 理 结果 集 的 方法 有 
两 个 : 第 一 ,使 用 SqlDataReader 对 象 (数据 阅读 器 ); 第 二 ,同时 使 用 SqlDataAdapter 对 象 
(数据 适配器 ) 和 DataSet 对 象 。 

不 过 ,使 用 DataReader 对 象 可 以 从 数据 库 中 得 到 只 读 的 、 只 能 向 前 的 数据 流 。 使 用 
SqlDataReader 对 象 还 可 以 提高 应 用 程序 的 性 能 ,减少 系统 开销 ,因为 同一 时 间 只 有 一 条 行 记 
录 在 内 存 中 。 

1. SqlDataReader 类 的 属性 和 方法 

SqlDataReader 类 的 常用 属性 如 表 12. 13 所 示 , 其 常用 方法 如 表 12. 14 所 示 。 


表 12.13 SqlDataReader 类 的 常用 属性 及 其 说 明 


属 性 说 明 
FieldCount 获取 当前 行 中 的 列 数 
JsClosed 获取 一 个 布尔 值 ,指出 SqlDataReader 对 象 是 否 关闭 
RecordsAffected 获取 执行 SQL 语句 时 修改 的 行 数 


表 12.14 SqlDataReader 类 的 常用 方法 及 其 说 明 


方法 说 明 
Read 将 SqlDataReader 对 象 前 进 到 下 一 行 并 读 取 , 返 回 布尔 值 指示 是 否 有 多 行 
Close 关闭 SqlDataReader 对 象 
IsSDBNull 返回 布尔 值 , 表 示 列 是 否 包 含 NULL 值 
NextResult 将 SqlDataReader 对 象 移 到 下 一 个 结果 集 ,返回 布尔 值 指示 该 结果 集 是 否 有 多 行 
GetBoolean 返回 指定 列 的 值 , 类 型 为 布尔 值 
GetString 返回 指定 列 的 值 ,类 型 为 字符 串 
GetByte 返回 指定 列 的 值 ,类 型 为 字 节 
GetInt32 返回 指定 列 的 值 , 类 型 为 整 型 值 
GetDouble 返回 指定 列 的 值 , 类 型 为 双 精 度 值 
GetDataTime 返回 指定 列 的 值 ,类 型 为 日 期 时 间 值 
GetOrdinal 返回 指定 列 的 序号 或 数字 位 置 ( 首 列 序号 为 0) 
GetBoolean 返回 指定 列 的 值 ,类 型 为 对 象 


2. 创建 SqlDataReader 对 象 
在 ADO.NET 中 从 来 不 会 显 式 地 使 用 SqlDataReader 对 象 的 构造 函数 创建 的 SqlDataReader 
对 象 。 事 实 上 ,SqlDataReader 类 没有 提供 公有 的 构造 函数 。 人 们 通常 调用 Command 类 的 
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ExecuteReader 方法 ,这 个 方法 将 返回 一 个 SqlDataReader 对 象 。 例 如 ,以 下 代码 创建 一 个 
SqlDataReader 对 象 myreader: 

SqlCommand cmd = new SqlCommand(CommandText, ConnectionObject); 

SqlDataReader myreader = cmd. ExecuteReader(); 

注意 : SqlDataReader 对 象 不 能 使 用 new 来 创建 。 

SqlDataReader 对 象 最 常见 的 用 法 就 是 检索 SQL 查询 或 存储 过 程 执行 后 返回 的 记录 集 。 
另外 ,SqlDataReader 是 一 个 连接 的 、 只 向 前 的 和 只 读 的 记录 集 。 也 就 是 说 , 当 使 用 数据 阅读 
器 时 必须 保持 连接 处 于 打开 状态 。 除 此 之 外 ,可 以 从 头 到 尾 浏览 记录 集 ,而 且 也 只 能 以 这 样 的 
次 序 浏览 。 这 就 意味 着 不 能 在 某 条 记录 处 停 下 来 向 回 移动 。 记 录 是 只 读 的 ,因此 数据 阅读 器 
类 不 提供 任何 修改 数据 库 记 录 的 方法 。 

注意 ; SqlDataReader 对 象 使 用 底层 的 连接 ,该 连接 是 它 专 有 的 。 当 SqlDataReader 对 象 
打开 时 ,不 能 使 用 对 应 的 连接 对 象 执 行 其 他 任何 任务 ,例如 执行 另外 的 命令 等 。 当 不 再 需要 
SqlDataReader 对 象 的 记录 时 应 该 立刻 关闭 它 。 

3. 遍历 SqlDataReader 对 象 的 记录 

当 ExecuteReader 方法 返回 SqlDataReader 对 象 时 ,当前 光标 的 位 置 是 第 一 条 记录 的 前 
面 。 用 户 必须 调用 SqlDataReader 对 象 的 Read 方法 把 光标 移动 到 第 一 条 记录 ,然后 第 一 条 记 
录 将 变 成 当前 记录 。 如 果 SqlDataReader 对 象 中 包含 的 记录 不 止 一 条 ,Read 方法 就 返回 一 个 
Boolean 值 True。 如 果 想 要 移动 到 下 一 条 记录 ,需要 再 次 调用 Read 方法 。 重复 上 述 过 程 , 直 
到 最 后 一 条 记录 ,此 时 Read 方法 将 返回 False。 经 常 使 用 While 循环 来 遍历 记录 ， 

while (myreader. Read( ) ) 

| // 读 取 数 据 

} 

只 要 Read 方法 返回 的 值 为 True, 就 可 以 访问 当前 记录 中 包含 的 字段 。 

4. 访问 字段 中 的 值 

使 用 以 下 语句 获取 一 个 SqlDataReader 对 象 : 

SqlDataReader myreader = mycmd.ExecuteReader(); 


然后 ADO.NET 提供 了 两 种 方法 来 访问 记录 中 的 字段 。 第 一 种 是 Item 属性 ,此 属性 返 
回 由 字段 索引 或 字段 名 指定 的 字段 值 ; 第 二 种 方法 是 Get 方法 ,此 方法 返回 由 字段 索引 指定 
的 字段 的 值 。 

(1) Item 属性 

每 一 个 SqlDataReader 对 象 都 定义 了 一 个 Item 属性 ,此 属性 返回 一 个 代码 字段 属性 的 对 
象 。Item 属性 是 SqlDataReader 对 象 的 索引 。 需 要 注意 的 是 Item 属性 总 是 基于 0 开始 编 
号 的 ; 

myreader[FieldName] 

myreader[FieldIndex] 

可 以 把 包含 字段 名 的 字符 串 传递 给 Item 属性 ,也 可 以 把 指定 字段 索引 的 32 位 整数 传递 
给 Item 属性 。 例 如 ,如 果 命 令 是 SELECT 查询 : 


SELECT ID, cName FROM course 
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使 用 下 面 任意 一 种 方法 都 可 以 得 到 两 个 被 返回 字段 的 值 : 

myreader["ID"] 

myreader["cName"] 

或 者 : 

myreader[0] 

myreader[1] 

(2) Get 方法 

每 一 个 SqlDataReader 对 象 都 定义 了 一 组 Get 方法 ,这 些 方法 将 返回 适当 类 型 的 值 。 例 
如 ,GetInt32 方法 把 返回 的 字段 值 作 为 32 位 整数 ,每 一 个 Get 方法 都 将 接受 字段 的 索引 。 例 
如 ,在 上 面 的 例子 中 使 用 以 下 代码 可 以 检索 ID 字段 和 cName 字段 的 值 : 

myreader. GetInt32(0) 

myreader. GetString(1) 

【 例 12. 14】 设计 一 个 通过 SqlDataReader 对 象 在 一 个 列表 框 中 输出 所 有 学 生 记录 的 网 
页 WebForms5 。 

解 : 其 步骤 如 下 。 

@ 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm5 空 网 页 。 

@ 其 设计 界面 如 图 12. 22 所 示 , 其 中 包含 一 个 列表 框 ListBoxl 和 一 个 Button 控件 
Buttonl 。 在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Button1_Click(object sender, EventArgs e) 


{ 


} 


string mystr, mysql; 

SqlConnection myconn = new SqlConnection(); 

SqlCommand mycmd = new SqlCommand(); 

mystr = System.Configuration. ConfigurationManager. 

ConnectionStrings["myconnstring"]. ToString(); 

myconn. ConnectionString = mystr; 

myconn. Open( ); 

mysql = "SELECT * FROM student"; 

mycmd. CommandText = mysql; 

mycmd. Connection = myconn; 

SqlDataReader myreader = mycmd. ExecuteReader(); 

ListBox1. Items. Add(" 学 号 姓名 性 别 民族 班 号 "); 

ListBoxl. Items. Add(" ======================="); 

while (myreader. Read( )) // 循 环 读 取信 息 

ListBox1. Items. Add(String. Format("{0} {1} {2} {3} {4}", 

myreader[" 学 号 "].ToString(), myreader[1].ToString(), 
myreader[2]. ToString(), myreader[3].ToString(), 
myreader[4]. ToString())); 

myconn. Close(); 

myreader. Close( ); 


@ 单 击 工具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 ,然后 单 击 “ 输 出 学 生 记录 ”命令 按钮 ， 
运行 界面 如 图 12.23 所 示 。 


未 缘 定 


-输出 学 生 记录 
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名 httpy//localhost5115, pro 


办 localhost X 
| 学 号 姓名 性 别 民族 班 号 


中 | 主 华 女 汉族 09001 
2 孙 丽 女 汉族 09002 
3 李兵 男 满族 09001 
6 张 军 男 汉族 09001 
| 8 马 棋 男 回族 09002 


4 


» 
5 设计 |a 拆 分 |。 源 | [4] <aspiistBoxsL|》] 


- 


图 12.22 WebForm5 网 页 设计 界面 图 12.23 WebForm5 网 页 运行 界面 


12.3.4 SqlDataAdapter 对 象 


SqlDataAdapter 对 象 (数据 适配器 ) 可 以 执行 SQL 命令 以 及 调用 存储 过 程 、 传 递 参数 ,最 


重要 的 是 取得 数据 结果 集 ,在 数据 库 和 DataSet 对 象 之 间 来 回 传输 数据 。 
1. SqlDataAdapter 类 的 属性 和 方法 
SqlDataAdapter 类 的 常用 属性 如 表 12. 15 所 示 ,其 常用 方法 如 表 12. 16 所 示 。 


表 12.15 SqlDataAdapter 类 的 常用 属性 及 其 说 明 


属 性 


说 明 


SelectCommand 


InsertCommand 


UpdateCommand 
DeleteCommand 


AcceptChangesDuringFill 


获取 或 设置 SQL 语句 用 于 选择 数据 源 中 的 记录 。 该 值 为 SqlCommand 对 象 
获取 或 设置 SQL 语句 用 于 将 新 记录 插入 到 数据 源 中 。 该 值 为 SqlCommand 
对 象 

获取 或 设置 SQL 语句 用 于 更 新 数据 源 中 的 记录 。 该 值 为 SqlCommand 对 象 
获取 或 设置 SQL 语句 用 于 从 数据 集中 删除 记录 。 该 值 为 SqlCommand 对 象 
获取 或 设置 一 个 值 ,该 值 指示 在 任何 Fill 操作 过 程 中 是 否 接受 对 行 所 做 的 
修改 


AcceptChangesDuringUpdate 获取 或 设置 在 Update 期 间 是 否 调 用 AcceptChanges 


FillLoadOption 


MissingMappingAction 


MissingSchemaAction 


TableMappings 


表 12.16 SqlDataAdapter 类 的 常用 方法 及 其 说 明 


获取 或 设置 LoadOption, 后 者 确定 适配器 如 何 从 SqlDataReader 中 十 
充 DataTable 

确定 传人 数据 没有 匹配 的 表 或 列 时 需要 执行 的 操作 

确定 现 有 DataSet 架构 与 传人 数据 不 匹配 时 需要 执行 的 操作 


方 ”法 说 明 
Fill 用 来 自动 执行 SqlDataAdapter 对 象 的 SelectCommand 属性 中 相对 应 的 SQL 语句 ， 
以 检索 数据 库 中 的 数据 ,然后 更 新 数据 集中 的 DataTable 对 象 , 如 果 DataTable 对 
象 不 存在 , 则 创建 它 
FillSchema 将 DataTable 添加 到 DataSet 中 ,并 配置 架构 以 匹配 数据 源 中 的 架构 
GetFillParameters ”获取 当 执 行 SELECT 语句 时 由 用 户 设置 的 参数 
Update 用 来 自动 执行 UpdateCommand InsertCommand 或 DeleteCommand 属性 相对 应 的 


SQL 语句 ,以 使 数据 集中 的 数据 来 更 新 数据 库 
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实际 上 ,使 用 SqlDataAdapter 对 象 的 主要 目的 是 取得 DataSet 对 象 。 另 外 它 还 有 一 个 功 
能 ,就 是 数据 写 回 更 新 的 自动 化 。 因 为 DataSet 对 象 为 离线 存 取 ,因此 数据 的 添加 、 删 除 、 修 改 
都 在 DataSet 中 进行 , 当 需 要 数据 批 次 写 回 数据 库 时 , SqlDataAdapter 对 象 提供 了 一 个 
Update 方法 , 它 会 自动 将 DataSet 中 不 同 的 内 容 取 出 ,然后 自动 判断 添加 的 数据 并 使 用 
InsertCommand 所 指定 的 INSERT 语句 ,修改 的 记录 使 用 UpdateCommand 所 指定 的 UPDATE 
语句 ,删除 的 记录 使 用 DeleteCommand 指定 的 DELETE 请 句 来 更 新 数据 库 的 内 容 。 

在 写 回 数据 来 源 时 ,DataTable 与 实际 数据 的 数据 表 及 列 的 对 应 可 以 通过 TableMappings 
定义 对 应 关系 。 

2. 创建 SqlDataAdapter 对 象 

SqlDataAdapter 类 有 以 下 构造 函数 : 


SqlDataAdapter( ); 

SqlDataAdapter( selectCommandText); 

SqlDataAdapter( selectCommandText, selectConnection); 

SqlDataAdapter( (selectCommandText, selectConnectionString); 

其 中 , selectCommandText 是 一 个 字符 串 , 包含 SQL SELECT 语句 或 存储 过 程 ; 
selectConnection 是 当前 连接 的 SqlConnection 对 象 ; selectConnectionString 是 连接 字符 串 。 

采用 上 述 第 3 个 构造 函数 创建 SqlDataAdapter 对 象 的 过 程 是 先 建立 SqlConnection 连接 
对 象 , 接 着 建立 SqlDataAdapter 对 象 , 在 建立 该 对 象 的 同时 可 以 传递 两 个 参数 , 即 命令 字符 串 
(mysql) 和 连接 对 象 (myconn)。 例 如 : 

string mystr, mysql; 

SqlConnection myconn = new SqlConnection(); 

mystr = System. Configuration. ConfigurationManager. 

ConnectionStrings["myconnstring"]. ToString(); 

myconn. ConnectionString = mystr; 

myconn. Open( ); 

mysql = "SELECT * FROM student"; 

SqlDataAdapter myadapter = new SqlDataAdapter(mysql,myconn); 

myconn. Close( ); 

以 上 代码 仅 创建 了 SqlDataAdapter 对 象 ,并 没有 使 用 它 , 在 后 面 介 绍 DataSet 对 象 时 将 大 
量 使 用 SqlDataAdapter 对 象 。 

3. 使 用 Fill 方法 

Fill 方法 用 于 向 DataSet 对 象 填 充 从 数据 源 中 读 取 的 数据 。 

调用 Fill 方法 的 语法 格式 有 多 种 ,常见 的 格式 如 下 : 

SqlDataAdapter 对 象 名 .Fill(DataSet 对 象 名 , "数据 表 名 "); 


其 中 第 一 个 参数 是 数据 集 对 象 名 ,表示 要 填充 的 数据 集 对 象 ; 第 二 个 参数 是 一 个 字符 串 ， 
表示 在 本 地 缓冲 区 中 建立 的 临时 表 的 名 称 。 例 如 ,以 下 语句 用 course 表 数 据 填充 数据 集 
mydatasetl : 


SqlDataAdapter]. Fill(mydatasetl, "course" ) 7 


使 用 Fill 方法 要 注意 以 下 几 点 : 
。 如 果 在 调用 Fill() 之 前 连接 已 关闭 , 则 先 将 其 打开 以 检索 数据 ,数据 检索 完成 后 再 将 连 
接 关闭 。 如 果 在 调用 Fill() 之 前 连接 已 打开 ,连接 仍然 会 保持 打开 状态 。 
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。 如 果 数 据 适 配器 在 填充 DataTable 时 遇 到 重复 列 ,它们 将 以 “columnnamel”、 
“columnname2”、“columnname3” 等 形式 命名 后 面 的 列 。 
。 如 果 传 入 的 数据 包含 未 命名 的 列 , 它 们 将 以 “column1”、“column2” 等 形式 命名 并 存 入 
DataTable。 
。 在 向 DataSet 添加 多 个 结果 集 时 ,每 个 结果 集 都 放 在 一 个 单独 的 表 中 。 
。 可 以 在 同一 个 DataTable 中 多 次 使 用 Fill() 方 法 。 如 果 存 在 主键 , 则 传人 的 行 会 与 已 
有 的 匹配 行 合 并 ; 如 果 不 存在 主键 . 则 传人 的 行 会 追加 到 DataTable 中 。 
4. 使 用 Update 方法 
Update 方 法 用 于 将 数据 集 DataSet 对 象 中 的 数据 按 InsertCommand 属性 .DeleteCommand 
属性 和 UpdateCommand 属性 所 指定 的 要 求 更 新 数据 源 , 即 调用 3 个 属性 中 所 定义 的 SQL 语 
句 来 更 新 数据 源 。 
Update 方法 常见 的 调用 格式 如 下 : 
SqlDataAdapter 对 象 名 .Update(DataSet 对 象 名 , [数据 表 名 ]); 
其 中 第 一 个 参数 是 数据 集 对 象 名 ,表示 要 将 哪个 数据 集 对 象 中 的 数据 更 新 到 数据 源 中 ; 
第 二 个 参数 是 一 个 字符 串 ,表示 临时 表 的 名 称 。 
由 于 SqlDataAdapter 对 象 介 于 DataSet 对 象 和 数据 源 之 间 , Update 方法 只 能 将 DataSet 
中 的 修改 回 存 到 数据 源 中 ,有 关 修 改 DataSet 对 象 中 数据 的 方法 将 在 下 一 节 介绍 。 那 么 当 用 
户 修 改 DataSet 对 象 中 的 数据 时 ,如 何 产 生 SqlDataAdapter 对 象 的 InsertCommand、 
DeleteCommand 和 UpdateCommand 属性 呢 ? 
系统 提供 了 SqlCommandBuilder 类 , 它 根据 用 户 对 DataSet 对 象 数据 的 操作 自动 生成 相 
应 的 InsertCommand .DeleteCommand 和 UpdateCommand 属性 值 。 该 类 的 构造 函数 如 下 : 
SqlCommandBuilder(adapter); 
其 中 ,adapter 是 一 个 SqlDataAdapter 对 象 的 名 称 。 例 如 ,以 下 语句 创建 一 个 SqlCom 
mandBuilder 对 象 mycmdbuilder, 用 于 产生 myadp 对 象 的 InsertCommand、 DeleteCommand 
和 UpdateCommand 属性 值 ,然后 调用 Update 方法 执行 这 些 修改 命令 ,以 更 新 数据 源 : 


SqlCommandBuilder mycmdbuilder = new SqlCommandBuilder(myadp); 
myadp. Update( myds, "student"); 


12.4 DataSet 对 象 


DataSet 是 ADO.NET 数据 库 访问 组 件 的 核心 ,主要 是 用 来 支持 ADO. NET 的 不 连贯 连 
接 及 数据 分 布 。 它 的 数据 驻 留 内 存 , 可 以 保证 和 数据 源 无 关 的 一 致 的 关系 模型 ,用 于 多 个 异种 
数据 源 的 数据 操作 。DataSet 类 位 于 Syatem. Data 命名 空间 。 


12.4.1 DataSet 对 象 概述 


ADO.NET 包含 多 个 组 件 ,每 个 组 件 在 访问 数据 库 时 具有 自己 的 功能 ,如 图 12. 24 所 示 。 
首先 通过 Connection 组 件 建立 与 实际 数据 库 的 连接 ,Command 组 件 发 送 数据 库 的 操作 命令 。 
一 种 方式 是 使 用 DataReader 组 件 ( 含 有 命令 执行 提取 的 数据 库 数 据 ) 与 C# 窗 体 控件 进行 数 
据 绑 定 , 即 在 窗 体 中 显示 DataReader 组 件 中 的 数据 集 ,这 在 上 一 节 已 介绍 过 ; 另 一 种 方式 是 


Ea 
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通过 DataAdapter 组 件 将 命令 执行 提取 的 数据 库 数据 填充 到 DataSet 组 件 中 ,再 通过 DataSet 
组 件 与 C# 窗 体 控件 进行 数据 绑 定 ,这 是 本 节 要 介绍 的 内 容 , 这 种 方式 功能 更 强 。 


.NET Framework 
数据 提供 程序 


让 


ii 
数据 库 十 | Connection 一 Command 


0 


DataReader 


Ea 


网 页 


图 12.24 ADO.NET 组 件 访问 数据 库 的 方式 


数据 集 DataSet 对 象 可 以 分 为 类 型 化 数据 集 和 非 类 型 化 数据 集 。 

类 型 化 DataSet 数据 集 继承 自 DataSet 基 类 ,包含 结构 描述 信息 ,是 结构 描述 文件 所 生成 
类 的 实例 ,C# 对 类 型 化 数据 集 提供 了 较 多 的 可 视 化 工具 支持 ,使 访问 类 型 化 数据 集中 的 数据 
表 和 字段 内 容 更 加 方便 ,快捷 且 不 容易 出 错 ,类 型 化 数据 集 提供 了 编译 阶段 的 类 型 检查 功能 。 

在 非 类 型 化 DataSet 数据 集中 ,DataSet 对 象 没 有 对 应 的 内 建 结构 描述 ,本 身 所 包括 的 表 、 
字段 等 数据 对 象 以 集合 的 方式 呈现 ,对 于 动态 建立 的 且 不 需要 使 用 结构 描述 信息 的 对 象 则 应 
该 使 用 非 类 型 化 数据 集 , 可 以 使 用 DataSet 的 WriteXmlSchema 方法 将 非 类 型 化 数据 集 的 结 


构 导 出 到 结构 描述 文件 中 。 


创建 DataSet 对 象 有 多 种 方法 , 既 可 以 使 用 设计 工具 ,也 可 以 使 用 程序 代码 来 创建 
DataSet 对 象 。 使 用 程序 代码 创建 DataSet 对 象 的 语法 格式 如 下 : 
DataSet 对 象 名 = new DataSet(); 


或 


DataSet 对 象 名 = new DataSet(dataSetName) ; 


其 中 ,dataSetName 为 一 个 字符 串 , 用 于 指出 DataSet 的 名 称 。 
12.4.2 DataSet 对 象 的 属性 和 方法 


1. DataSet 对 象 的 属性 


DataSet 对 象 的 常用 属性 如 表 12. 17 所 示 。DataSet 对 象 如同 内 存 中 的 数据 库 ,一 个 


DataSet 对 象 包含 一 个 Tables 属性 ( 表 集 合 ) 和 一 个 Relations 


属性 ( 表 之 间 关 系 的 集合 )。 


表 12.17 DataSet 对 象 的 常用 属性 及 其 说 明 
说 


属 性 


CaseSensitive 
DataSetName 
Relations 
Tables 


获取 或 设置 一 个 值 ,该 值 指示 DataTable 对 象 中 的 字符 串 比 较 是 否 区 分 大 小 写 
获取 或 设置 当前 DataSet 的 名 称 
获取 用 于 将 表 连 接 起 来 并 允许 从 父 表 浏 览 到 子 表 的 关系 的 集合 
获取 包含 在 DataSet 中 的 表 的 集合 
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2. DataSet 对 和 象 的 方法 
DataSet 对 象 的 常用 方法 如 表 12. 18 所 示 。 
表 12. 18 DataSet 对 象 的 常用 方法 及 其 说 明 


DataSet 对 象 的 方法 说 明 

AcceptChanges 提交 自 加 载 此 DataSet 或 上 次 调用 AcceptChanges 以 来 对 其 进行 的 所 有 更 改 

Clear 通过 移 除 所 有 表 中 的 所 有 行 来 清除 任何 数据 的 DataSet 

CreateDataReader ”为 每 个 DataTable 返回 带 有 一 个 结果 集 的 DataTableReader, 顺 序 与 Tables 集合 中 
表 的 显示 顺序 相同 

GetChanges 获取 DataSet 的 副本 ,该 副本 包含 自 上 次 加 载 以 来 或 自 调用 AcceptChanges 以 来 对 
该 数据 集 进行 的 所 有 更 改 

HasChanges 获取 一 个 值 , 该 值 指示 DataSet 是 否 有 更 改 , 包 括 新 增 行 .已 删除 的 行 或 已 修改 的 行 

Merge 将 指定 的 DataSet DataTable 或 DataRow 对 象 的 数组 合并 到 当前 的 DataSet 或 
DataTable 中 

Reset 将 DataSet 重 置 为 其 初始 状态 


12.4.3 Tables 集合 和 DataTable 对 象 


DataSet 对 象 的 Tables 属性 由 表 组 成 ,每 个 表 是 一 个 DataTable 对 象 。 实 际 上 ,每 一 个 
DataTable 对 象 代 表 了 数据 库 中 的 一 个 表 , 每 个 DataTable 数据 表 都 由 相应 的 行 和 列 组 成 。 
用 户 可 以 通过 索引 引用 Tables 集合 中 的 一 个 表 。 例 如 ,Tables[ 门 表示 第 i 个 表 , 其 索引 
值 从 0 开始 编号 。 
1. Tables 集合 的 属性 和 方法 
Tables 集合 的 常用 属性 如 表 12. 19 所 示 , 其 常用 方法 如 表 12. 20 所 示 。 
表 12. 19 Tables 集合 的 常用 属性 及 其 说 明 


Tables 集合 的 属性 说 明 
Count Tables 集合 中 表 的 个 数 
ltem 检索 Tables 集合 中 指定 索引 处 的 表 


表 12. 20 Tables 集合 的 常用 方法 及 其 说 明 


Tables 集合 的 方法 说 明 
Add 向 Tables 集合 中 添加 一 个 表 
AddRange 向 Tables 集合 中 添加 一 个 表 的 数组 
Clear 移 除 Tables 集合 中 的 所 有 表 
Contains 确定 指定 表 是 否 在 Tables 集合 中 
Equqls 判断 是 否 等 于 当前 对 象 
GetType 获取 当前 实例 的 Type 
Insert 将 一 个 表 插入 到 Tables 集合 中 指定 的 索引 处 
IndexOf 检索 指定 的 表 在 Tables 集合 中 的 索引 
Remove 从 Tables 集合 中 移 除 指定 的 表 
RemoveAt 移 除 Tables 集合 中 指定 索引 处 的 表 


2. DataTable 对 象 
DataTable 对 象 的 常用 属性 如 表 12. 21 所 示 。 一 个 DataTable 对 象 包含 一 个 Columns 属 
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性 ( 即 列 集合 ) 和 一 个 Rows 属性 (即行 集合 ) 。DataTable 对 象 的 常用 方法 如 表 12. 22 所 示 。 
DataSet 对 象 由 若干 个 DataTable 对 象 组 成 ,可 以 使 用 DataSet. Tables[" 表 名 "] 或 
DataSet. Tables[" 表 索引 " ] 来 引用 其 中 的 DataTable 对 象 。 


表 12.21 DataTable 对 象 的 常用 属性 及 其 说 明 


属 性 说 明 
CaseSensitive 指示 表 中 的 字符 串 比较 是 否 区 分 大 小 写 
ChildRelations 获取 此 DataTable 的 子 关 系 的 集合 
Columns 获取 属于 该 表 的 列 的 集合 
Constraints 获取 由 该 表 维护 的 约束 的 集合 
DataSet 获取 此 表 所 属 的 DataSet 
DefaultView 返回 可 用 于 排序 .筛选 和 搜索 DataTable 的 DataView 
ExtendedProperties 获取 自 定义 用 户 信 息 的 集合 
ParentRelations 获取 该 DataTable 的 父 关系 的 集合 
PrimaryKey 获取 或 设置 充当 数据 表 主 键 的 列 的 数组 
Rows 获取 属于 该 表 的 行 的 集合 
TableName 获取 或 设置 DataTable 的 名 称 


表 12.22 ” DataTable 对 象 的 常用 方法 及 其 说 明 


方 法 说 明 
AcceptChanges 提交 自 上 次 调用 AcceptChanges 以 来 对 该 表 进 行 的 所 有 更 改 
Clear 清除 所 有 数据 的 DataTable 
Compute 计算 用 来 传递 筛选 条 件 的 当前 行 上 的 给 定 表 达 式 
CreateDataReader 返回 与 此 DataTable 中 的 数据 相对 应 的 DataTableReader 
ImportRow 将 DataRow 复制 到 DataTable 中 ,保留 任何 属性 设置 以 及 初始 值 和 当前 值 
Merge 将 指定 的 DataTable 与 当前 的 DataTable 合并 
NewRow 创建 与 该 表 具有 相同 架构 的 新 DataRow 
Select 获取 DataRow 对 象 的 数组 


3. 建立 包含 在 数据 集中 的 表 

建立 包含 在 数据 集中 的 表 的 方法 主要 有 以 下 两 种 。 

(1) 利用 数据 适配器 的 Fill 方法 自动 建立 DataSet 中 的 DataTable 对 象 

先 通过 SqlDataAdapter 对 象 从 数据 源 中 提取 记录 数据 ,然后 调用 其 Fill 方法 ,将 所 提取 
的 记录 存 人 DataSet 中 对 应 的 表 内 .如果 DataSet 中 不 存在 对 应 的 表 ,Fill 方法 会 先 建立 表 再 
将 记录 填 入 其 中 。 例 如 ,以 下 语句 向 DataSet 对 象 myds 中 添加 一 个 表 course 及 其 包含 的 数 
据 记 录 : 

DataSet myds = new DataSet(); 

SqlDataAdapter myda = new SqlDataAdapter("SELECT x FROM course",myconn); 

myda. Fill(myds, "course"); 

(2) 将 建立 的 DataTable 对 象 添加 到 DataSet 中 

先 建立 DataTable 对 象 , 然后 调用 DataSet 的 表 集 合 属性 Tables 的 Add 方法 将 
DataTable 对 象 添加 到 DataSet 对 象 中 。 例 如 ,以 下 语句 向 DataSet 对 象 myds 中 添加 一 个 表 ， 
并 返回 表 的 名 称 course: 
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DataSet myds = new DataSet(); 
DataTable mydt = new DataTable("course"); 


myds. Tables. Add(mydt ); 
textBoxl. Text = myds.Tables["course"].TableName;// 文 本 框 中 显示 "course" 


4.4 Columns 集合 和 DataColumn 对 象 


DataTable 对 象 的 Columns 属性 是 由 列 组 成 的 ,每 个 列 是 一 个 DataColumn 对 象 。 


DataColumn 对 象 描述 数据 表 列 的 结构 ,要 向 数据 表 添 加 一 个 列 , 必 须 先 建立 一 个 DataColumn 
对 象 ,设置 其 各 项 属性 ,然后 将 它 添 加 到 DataTable 的 列 集合 DataColumns 中 。 


1. Columns 集合 的 属性 和 方法 
Columns 集合 的 常用 属性 如 表 12. 23 所 示 , 其 常用 方法 如 表 12. 24 所 示 。 
表 12.23 Columns 集合 的 常用 属性 及 其 说 明 


Columns 集合 的 属性 说 明 
Count Columns 集合 中 列 的 个 数 
Item 检索 Columns 集合 中 指定 索引 处 的 列 


表 12.24 Columns 集合 的 常用 方法 及 其 说 明 


Columns 集合 的 方法 说 明 
Add 向 Columns 集合 中 添加 一 个 列 
AddRange 向 Columns 集合 中 添加 一 个 列 的 数组 
Clear 移 除 Columns 集合 中 的 所 有 列 
Contains 确定 指定 列 是 否 在 Columns 集合 中 
Equqls 判断 是 否 等 于 当前 对 象 
GetType 获取 当前 实例 的 Type 
Insert 将 一 个 列 插入 到 Columns 集合 中 指定 的 索引 处 
IndexOf 检索 指定 的 列 在 Columns 集合 中 的 索引 
Remove 从 Columns 集合 中 移 除 指定 的 列 
RemoveAt 移 除 Columns 集合 中 指定 索引 处 的 列 


2. DataColumn 对 象 
DataColumn 对 象 的 常用 属性 如 表 12. 25 所 示 , 其 方法 很 少 使 用 。 
表 12.25 DataColumn 对 象 的 常用 属性 及 其 说 明 


属 ”性 说 明 
AllowDBNull 获取 或 设置 一 个 值 ,该 值 指示 对 于 属于 该 表 的 行 此 列 中 是 否 允 许 空 
Caption 获取 或 设置 列 的 标题 
ColumnName 获取 或 设置 DataColumnCollection 中 的 列 的 名 称 
DataType 获取 或 设置 存储 在 列 中 的 数据 的 类 型 
DefaultValue 在 创建 新 行 时 获取 或 设置 列 的 默认 值 
Expression 获取 或 设置 表达 式 , 用 于 筛选 行 . 计 算 列 中 的 值 或 创建 聚合 列 
MaxLength 获取 或 设置 文本 列 的 最 大 长 度 
Table 获取 列 所 属 的 DataTable 


Unique 获取 或 设置 一 个 值 ,该 值 指示 列 的 每 一 行 中 的 值 是 否 必 须 是 唯一 的 
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例如 ,以 下 语句 在 内 存 中 建立 一 个 DataSet 对 象 myds, 向 其 中 添加 一 个 DataTable 对 象 


mydt, 向 mydt 中 添加 3 个 列 , 列 名 分 别 为 ID、cName 和 cBook, 数 据 类 型 均 为 String: 


DataTable mydt = new DataTable(); 

DataColumn mycoll = mydt.Columns.Add("ID", Type.GetType("System.String")); 
mydt. Columns. Add( "cName", Type.GetType("System.String")); 

mydt. Columns. Add( "cBook", Type. GetTYpe("System. String")); 


12.4.5 ”Rows 集合 和 DataRow 对 象 


DataTable 对 象 的 Rows 属性 是 由 行 组 成 的 ,每 个 行 都 是 一 个 DataRow 对 象 。DataRow 
对 象 用 来 表示 DataTable 中 单独 的 一 条 记录 。 每 一 条 记录 都 包含 多 个 字段 ,DataRow 对 象 的 


Item 属性 表示 这 些 字段 ,Item 属性 加 上 索引 值 或 字段 名 表示 指定 的 字段 值 。 
1. Rows 集合 的 属性 和 方法 
Rows 集合 的 常用 属性 如 表 12. 26 所 示 ,其 常用 方法 如 表 12. 27 所 示 。 


表 12.26 Rows 集合 的 常用 属性 及 其 说 明 


Rows 集合 的 属性 说 明 
Count Rows 集合 中 行 的 个 数 
ltem 检索 Rows 集合 中 指定 索引 处 的 行 


表 12.27 Rows 集合 的 常用 方法 及 其 说 明 


Rows 集合 的 方法 说 明 
Add 向 Rows 集合 中 添加 一 个 行 
AddRange 向 Rows 集合 中 添加 一 个 行 的 数组 
Clear 移 除 Rows 集合 中 的 所 有 行 
Contains 确定 指定 行 是 否 在 Rows 集合 中 
Equqls 判断 是 否 等 于 当前 对 象 
GetType 获取 当前 实例 的 Type 
Insert 将 一 个 行 插入 到 Rows 集合 中 指定 的 索引 处 
IndexOf 检索 指定 的 行 在 Rows 集合 中 的 索引 
Remove 从 Rows 集合 中 移 除 指定 的 行 
RemoveAt 移 除 Rows 集合 中 指定 索引 处 的 行 


2. DataRow 对 象 
DataRow 对 象 的 常用 属性 如 表 12. 28 所 示 ,其 方法 如 表 12. 29 所 示 。 


表 12. 28 DataRow 对 象 的 常用 属性 及 其 说 明 


属 性 说 明 

ltem 获取 或 设置 存储 在 指定 列 中 的 数据 
ltemArray 通过 一 个 数组 来 获取 或 设置 此 行 的 所 有 值 
Table 获取 该 行 拥有 其 架构 的 DataTable 


表 12.29 DataRow 对 象 的 常用 方法 及 其 说 明 


方 法 说 明 
AcceptChanges 提交 自 上 次 调用 AcceptChanges 以 来 对 该 行进 行 的 所 有 和 更改 
Delete 删除 DataRow 
EndEdit 终止 发 生 在 该 行 的 编辑 


IsNull 获取 一 个 值 ,该 值 指示 指定 的 列 是 否 包含 空 值 
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【 例 12.15】〗 设计 一 个 通过 DataSet 对 象 创建 一 个 表 并 显示 其 中 添加 的 记录 的 网 页 
WebForm6 。 

解 : 其 步骤 如 下 。 

Oa 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm6 空 网 页 。 

@ 其 设计 界面 如 图 12. 25 所 示 ,其 中 包含 一 个 GridView 控件 GridViewl 和 一 个 Button 
控件 Button1。 在 该 网 页 上 设计 如 下 事件 过 程 : 


using System. Data; 
protected void Button1_Click(object sender, EventArgs e) 
{ DataSet myds = new DataSet(); 
DataTable mydt = new DataTable("course"); 
myds. Tables. Add(mydt); 
mydt. Columns. Add( "ID", Type.GetType("System. String")); 
mydt. Columns. Add( "cName", Type.GetType("System. String")); 
mydt. Columns. Add( "cBook", Type.GetType("System. String")); 
DataRow myrowl = mydt.NewRow(); 
myrow1l["ID"] = "101"; 
myrowl["cName"] = "C 语言 "; 
myrowl[ "cBook"] = "C 语 言 教程 "; 
myds. Tables[ 0]. Rows. Rdd(myrowl) ; 
DataRow myrow2 = mydt. NewRow(); 
myrow2["ID"] = "120"; 
myrow2["cName"] = "数据 结构 "; 
myrow2["cBook"] = "数据 结构 教程 "; 
myds. Tables[0]. Rows. Add(myrow2); 
GridView1. DataSource = mydt; 
// 或 GridViewl.DataSource = myds.Tables["course"]; 
GridViewl. DataBind() ; 
} 


上 述 事件 过 程 在 内 存 中 建立 一 个 DataSet 对 象 myds, 向 其 中 添加 一 个 DataTable 对 象 
mydt, 向 mydt 中 添加 3 个 列 , 列 名 分 别 为 ID、cName 和 cBook, 数 据 类 型 均 为 String, 再 向 
mydt 中 添加 两 行 数据 。 通 过 设置 GridViewl 的 DataSource 属性 为 mydt 让 GridViewl 控件 
显示 表 数 据 。 有 关 GridView 控件 的 使 用 将 在 后 面 介绍 。 

@ 单 击 工 具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 ,然后 单 击 * 显 示 DataSet 中 的 表 ” 命 
令 按钮 ,运行 结果 如 图 12. 26 所 示 。 


| 非 类 型 化 DataSet 笋 据 集 全 | 个 htpWoaihestslls D 
CaiuaaoColuaallCcolumngl localhost x 
jabc abc labc | 


非 类 型 化 DataSet 孝 据 集 


ID| cName | cBook 
101|C 语 言 “|C 语 言 教程 
120| 数 据 结构 数据 结构 教程 


显示 DataSet 中 的 表 


[ 显示 DataSet 中 的 表 
OO 
设计 | 晶 拆 分 |。 源 | [4] <aspb] 


图 12.25 WebForm6 网 页 设计 界面 图 12. 26 WebForm6 网 页 运行 界面 
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12.5 数据 源 控件 


12.5.1 数据 源 控 件 概述 


ASP.NET 包含 一 些 数据 源 控 件 , 这 些 数据 源 控 件 允 许 用 户 使 用 不 同类 型 的 数据 源 , 如 数 
据 库 .XML 文件 或 中 间 层 业务 对 象 。 数 据 源 控件 用 于 连接 到 数据 源 , 从 中 检索 数据 ,并 使 得 
其 他 控件 可 以 绑 定 到 数据 源 而 无 须 代 码 。 数 据 源 控件 还 支持 修改 数据 。 

.NET 框架 提供 了 支持 不 同 数据 绑 定 方案 的 数据 源 控件 ,常用 的 数据 源 控件 如 表 12. 30 
所 示 ,它们 都 位 于 System. Web. UI. WebControls 命名 空间 。 

表 12.30 常用 的 数据 源 控件 及 其 说 明 
数据 源 控件 说 明 

SqlDataSource 表示 数据 绑 定 控件 的 SQL 数据 库 

ObjectDataSource ”表示 为 多 层 Web 应 用 程序 体系 结构 中 的 数据 绑 定 控件 提供 数据 的 业务 对 象 

XmlDataSource 表示 数据 绑 定 控件 的 XML 数据 源 

SiteMapDataSource ”提供 了 一 个 数据 源 控件 ,Web 服务 器 控件 及 其 他 控件 可 使 用 该 控件 绑 定 到 分 层 
的 站 点 地 图 数据 

EntityDataSource 表示 ASP.NET 应 用 程序 中 数据 绑 定 控件 的 实体 数据 模型 (EDMD) 

LinqDataSource 支持 通过 标记 文本 在 ASP.NET 网 页 中 使 用 语言 集成 查询 (LINQ) ,以 从 数据 对 
象 中 检索 和 修改 数据 


注意 : 数据 源 控件 仅 用 作 ASP.NET 网 页 和 数据 库 之 间 的 “桥梁 ”。 也 就 是 说 ,数据 源 控 
件 只 检索 数据 库 数 据 , 且 不 具有 任何 在 网 页 中 显示 所 检索 数据 的 能 力 。 如 果 要 显示 数据 ,需要 
使 用 相关 的 数据 绑 定 控件 ,如 GridView 等 。 

使 用 数据 源 控 件 的 优势 在 于 : 一 是 可 以 得 到 完全 声明 性 的 数据 绑 定 模型 ,新 的 模型 减少 
了 以 内 联 方 式 插 和 到, aspx 网 页 中 再 分 散在 代码 隐藏 类 中 的 松散 代码 ; 二 是 数据 源 控件 从 本 
质 上 改变 了 代码 的 质量 ,原来 添加 在 事件 过 程 中 的 代码 消失 ,被 插入 到 现 有 框架 中 的 组 件 所 代 
蔡 , 这 些 组 件 派 生 于 抽象 类 ,实现 了 已 知 的 接口 ,意味 着 更 高 级 别 的 可 重用 性 。 

本 节 讨 论 SqlDataSource 控件 和 LinkDataSource,XMLDataSource 控件 与 它们 类 似 , 主 要 
是 用 于 连接 XML 文档 。SiteMapDataSource 控件 在 第 10 章 已 介绍 .ObjectDataSource 和 
EntityDataSource 数据 源 控 件 将 在 后 面 几 章 介绍 。 


12.5.2 SqlDataSource 控件 


SqlDataSource 控件 位 于 工具 箱 的 “数据 ?类 别 中 ,图 标 为 呢 ”Sqlpatasource ,对 应 命名 空间 
System. Web. UI. WebControls 中 的 SqlDataSource 类 。SqlDataSource 控件 用 于 表示 到 Web 
应 用 程序 中 数据 库 的 直接 连接 。 数 据 绑 定 控 件 ( 如 GridView、DetailsView 和 FormView 控 
件 ) 可 以 使 用 SqlDataSource 控件 自动 检索 和 修改 数据 ,可 以 将 用 来 选择 .插入 .更 新 和 删除 数 
据 的 命令 指定 为 SqlDataSource 控件 的 一 部 分 ,并 让 该 控件 自动 执行 这 些 操作 。 用 户 无 须 编 
写 代码 来 创建 连接 并 指定 用 于 查询 和 更 新 数据 库 的 命令 。 

1. SqlDataSource 控件 的 属性 、 方 法 和 事件 

SqlDataSource 控件 的 构造 函数 如 下 。 
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。 SqlDataSource(): 初始 化 SqlDataSource 类 的 新 实例 。 


。 SqlDataSource(string connectionString, string selectCommand) : 使 用 指定 的 连接 字 


符 串 和 Select 命令 初始 化 SqlDataSource 类 的 新 实例 。 


。 SqlDataSource(string providerName,string connectionString,string selectCommand): 使 用 


指定 的 连接 字符 串 和 Select 命令 初始 化 SqlDataSource 类 的 新 实例 。 


其 中 ,providerName 参数 指出 SqlDataSource 使 用 的 数据 提供 程序 的 名 称 , 如 果 没 有 设置 
任何 提供 程序 , 则 在 默认 情况 下 SqlDataSource 使 用 Microsoft SQL Server 的 ADO. NET 提 
供 程 序 。connectionString 参数 作为 与 基础 数据 库 建立 连接 的 连接 字符 串 。selectCommand 
参数 用 于 从 基础 数据 库 中 检索 数据 的 SQL 查询 ,如 果 该 SQL 查询 是 参数 化 的 SQL 字符 串 ， 


可 能 需要 将 Parameter 对 象 添加 到 SelectParameters 集合 中 。 
SqlDataSource 控件 的 常用 属性 ,方法 和 事件 分 别 如 表 12. 31 一 表 12. 33 所 示 。 


属 ”性 


表 12.31 SqlDataSource 控件 的 常用 属性 及 其 说 明 


说 明 


ConnectionString 
DataSourceMode 
DeleteCommand 
DeleteCommandType 
DeleteParameters 
FilterExpression 
FilterParameters 
InsertCommand 
InsertCommandType 
JnsertParameters 


ProviderName 


SelectCommand 


SelectCommandType 


SelectParameters 


SortParameter Name 


UpdateCommand 


UpdateCommandType 


UpdateParameters 


获取 或 设置 特定 于 ADO.NET 提供 程序 的 连接 字符 串 ,SqlDataSource 控件 使 用 该 
字符 串 连接 基础 数据 库 

获取 或 设置 SqlDataSource 控件 获取 数据 所 用 的 数据 检索 模式 

获取 或 设置 SqlDataSource 控件 从 基础 数据 库 删除 数据 所 用 的 SQL 字符 串 

获取 或 设置 一 个 值 , 该 值 指示 DeleteCommand 属性 中 的 文本 是 SQL 语句 还 是 存储 
过 程 的 名 称 

从 与 SqlDataSource 控件 相关 联 的 SqlDataSourceView 对 象 获 取 包 含 DeleteCommand 
属性 所 使 用 的 参数 的 集合 

获取 或 设置 调用 Select 方法 时 应 用 的 筛选 表达 式 

获取 与 FilterExpression 字符 串 中 的 任何 参数 占 位 符 关 联 的 参数 的 集合 
获取 或 设置 SqlDataSource 控件 将 数据 插入 基础 数据 库 所 用 的 SQL 字符 串 

获取 或 设置 一 个 值 , 该 值 指示 InsertCommand 属性 中 的 文本 是 SQL 语句 还 是 存储 
过 程 的 名 称 

从 与 SqlDataSource 控件 相关 联 的 SqlDataSourceView 对 象 获取 包含 InsertCommand 
属性 所 使 用 的 参数 的 集合 

获取 或 设置 .NET Framework 数据 提供 程序 的 名 称 ,SqlDataSource 控件 使 用 该 提 
供 程序 来 连接 基础 数据 源 

获取 或 设置 SqlDataSource 控件 从 基础 数据 库 检索 数据 所 用 的 SQL 字符 串 

获取 或 设置 一 个 值 .该 值 指示 SelectCommand 属性 中 的 文本 是 SQL 查询 还 是 存储 
过 程 的 名 称 

从 与 SqlDataSource 控件 相关 联 的 SqlDataSourceView 对 象 获取 包含 SelectCommand 
属性 所 使 用 的 参数 的 集合 

获取 或 设置 存储 过 程 参数 的 名 称 , 在 使 用 存储 过 程 执行 数据 检索 时 该 存储 过 程 参 
数 用 于 对 检索 到 的 数据 进行 排序 

获取 或 设置 SqlDataSource 控件 更 新 基础 数据 库 中 的 数据 所 用 的 SQL 字符 串 

获取 或 设置 一 个 值 ,该 值 指示 UpdateCommand 属性 中 的 文本 是 SQL 语句 还 是 存 
储 过 程 的 名 称 

从 与 SqlDataSource 控件 相关 联 的 SqlDataSourceView 控件 获取 包含 UpdateCommand 
属性 所 使 用 的 参数 的 集合 
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表 12.32 SqlDataSource 控件 的 常用 方法 及 其 说 明 


方法 说 明 
DataBind 将 数据 源 绑 定 到 被 调用 的 服务 器 控件 及 其 所 有 子 控件 
Delete 使 用 DeleteCommand 字符 串 和 DeleteParameters 集合 中 的 所 有 参数 执行 删除 操作 
Insert 使 用 InsertCommand 字符 串 和 InsertParameters 集合 中 的 所 有 参数 执行 插入 操作 
Select 使 用 SelectCommand 字符 串 以 及 SelectParameters 集合 中 的 所 有 参数 从 基础 数据 库 中 检索 数据 
Update ”使 用 UpdateCommand 字符 串 和 UpdateParameters 集合 中 的 所 有 参数 执行 更 新 操作 


表 12.33 ”SqlDataSource 控件 的 常用 事件 及 其 说 明 


事件 说 盟 
DataBinding ” 当 服 务 器 控件 绑 定 到 数据 源 时 引发 

Deleted 完成 删除 操作 后 引发 

Deleting 执行 删除 操作 前 引发 

Disposed 当 从 内 存 释放 服务 器 控件 时 引发 ,这 是 请 求 ASP.NET 页 时 服务 器 控件 生存 期 的 最 后 阶段 
Filtering 执行 筛选 操作 前 引发 

Init 当 服 务 器 控件 初始 化 时 引发 ,初始 化 是 控件 生存 期 的 第 一 步 
Inserted 完成 插入 操作 后 引发 

Inserting 执行 插入 操作 前 引发 

Load 当 服 务 器 控件 加 载 到 Page 对 象 中 时 引发 

PreRender 在 加 载 Control 对 象 之 后 .呈现 之 前 引发 

Selected 完成 数据 检索 操作 后 引发 

Selecting 执行 数据 检索 操作 前 引发 

Unload 当 服务 器 控件 从 内 存 中 印 载 时 引发 

Updated 完成 更 新 操作 后 引发 

Updating 执行 更 新 操作 前 引发 


2. SqlDataSource 控件 的 功能 
SqlDataSource 控件 提供 了 选择 和 显示 数据 ,对 数据 进行 排序 .分 页 和 缓存 ,更 新 .插入 和 
删除 数据 ,使 用 运行 时 参数 筛选 数据 等 功能 ,其 主要 的 功能 及 要 求 如 表 12. 34 所 示 。 


表 12.34 SqlDataSource 控件 的 功能 及 其 要 求 


功 能 说 明 

缓存 将 DataSourceMode 属性 设置 为 DataSet 值 、EnableCaching 属性 设置 为 True, 并 根据 希望 缓 
存 数 据 所 具有 的 缓存 行为 设置 CacheDuration 和 CacheExpirationPolicy 属性 

删除 将 DeleteCommand 属性 设置 为 删除 数据 所 用 的 SQL 语句 。 此 语句 通常 是 参数 化 的 

筛选 将 DataSourceMode 属性 设置 为 DataSe 值 ,将 FilterExpression 属性 设置 为 在 调用 Select 方 
法 时 用 于 筛选 数据 的 筛选 表达 式 

插入 将 InsertCommand 属性 设置 为 插入 数据 所 用 的 SQL 语句 。 此 语句 通常 是 参数 化 的 

分 页 SqlDataSource 当前 不 支持 此 功能 ,但 是 将 DataSourceMode 属性 设置 为 DataSet 值 时 某 些 数 
据 绑 定 控件 (例如 GridView) 支 持 分 页 

选择 将 SelectCommand 属性 设置 为 检索 数据 所 用 的 SQL 语句 

排序 将 DataSourceMode 属性 设置 为 DataSet 

更 新 将 UpdateCommand 属性 设置 为 更 新 数据 所 用 的 SQL 语句 。 此 语句 通常 是 参数 化 的 
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3. 使 用 SqlDataSource 控件 连接 到 SOL Server 数据 库 

用 户 可 以 将 SqlDataSource 控件 连接 到 SQL Server 数据 库 , 然 后 使 用 某 些 控件 (例如 
GridView) 来 显示 或 编辑 数据 。 下 面 通过 一 个 示例 说 明 操作 过 程 。 

【 例 12. 16】 设计 一 个 通过 SqlDataSource 控件 来 访问 student 表 , 并 采用 GridView 控 
件 显示 所 有 记录 的 网 页 WebForm7 。 

解 : 其 步骤 如 下 。 

@ 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebFormy7 空 网 页 。 

@ 切换 到 设计 视图 ,从 工具 箱 的 “数据 ?类 别 中 将 SqlDataSource 控件 拖 动 到 网 页 上 。 如 
果 智 能 标记 面板 没有 显示 , 单 击 SqlDataSourcel 控件 右上 方 的 智能 标记 [9 。 

@ 在 “SqlDataSource 任务 ”列表 中 选择 “配置 数据 源 " 命 令 将 显示 “配置 数据 源 - 
SqlDataSourcel” 向 导 , 出 现 “ 选 择 您 的 数据 连接 "对话 框 ,如 图 12. 27 所 示 , 单 击 “ 新 建 连接 ” 
按钮 。 


配置 数 振 源 - SqlDataSourcel 


图。 ems 


? 


图 12.27 “选择 您 的 数据 连接 ”对 话 框 


@ 出 现 “ 添 加 连接 ”对 话 框 ,在 服务 器 名 ”中 输入 或 选择 LCB-PC\SQLEXPRESS” 项 , 选 
中 “使 用 SQL Server 身份 验证 ”, 在 "用户 名 ”文本 框 中 输入 “sa”, 在 “密码 ”文本 框 中 输入 
“12345”, 选 择 “Stud” 数 据 库 ,如 图 12. 28 所 示 。 单 击 “ 测 试 连接 ”按钮 后 出 现 连接 成 功 信息 , 单 
击 “ 确 定 ” 按 钮 返回 到 “选择 您 的 数据 连接 "对话 框 ,直接 单 击 " 下 一 步 " 按 钮 。 

@ 出 现 “ 将 连接 字符 串 保 存 到 应 用 程序 配置 文件 中 ”对 话 框 ,保持 默认 值 ,如 图 12. 29 所 
示 , 单 击 “ 下 一 步 " 按 钮 。 

若 这 一 步 中 勾 选 “是 ,将 此 连接 另存 为 ” 复 选 框 , 则 自动 在 Web. config 文件 的 
一 connectionStrings 之 节 中 添加 如 下 代码 : 


<add name = "StudConnectionString" connectionString = "Data Source= LCB— PC\SQLEXPRESS; 
Initial Catalog = Stud; User ID = sa; Password = 12345" 
providerName = "System. Data. SqlClient" /> 
其 中 ,StudConnectionString 连接 部 分 是 本 次 操作 新 增加 的 ,以 后 在 网 页 设计 中 可 以 使 用 
这 个 新 连接 。 
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Microsoft SQL Server (SqlClient) 


服务 器 名 (E): 


LCB-PC\SQLEXPRESS 


日 使 用 Windows 身份 验证 [W) 


图 使 用 SQL Server 身份 验证 (Q) 


用 户 名 (U): sa 


3(P)}: e0000 


图 12.28 “添加 连接 ”对 话 框 


,可 简化 维护 和 部 署 。 若 和 要 将 连接 字符 率 保存 到 应 用 程序 本 置 文件 中 ， 请 在 文本 框 中 输入 
一 个 名 称 ,然后 单 击 “ 下 一 步 ”。 如果 选 择 不 这 样 做 ， 则 连接 字符 率 棕 作为 数据 源 控件 的 屋 性 保存 在 该 页 中 。 


图 12.29 


“将 连接 字符 串 保 存 到 应 用 程序 配置 文件 中 ”对 话 框 
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@ 出 现 * 配 置 Select 语句 ”对 话 框 ,选择 student” 表 ,并 勾 选 所 有 列 , 如 图 12. 30 所 示 。 单 
击 “ 高 级 ”按钮 , 出 现 “ 高 级 SQL 生成 选项 ”对 话 框 , 勾 选 “生成 INSERT、UPDATE 和 
DELETE 语句 ” 复 选 框 ,如 图 12. 31 所 示 , 单 击 “ 确 定 ” 按 钮 返回 到 “配置 Select 语句 ”对 话 框 ， 
再 单 击 “ 下 一 步 ” 按 钮 。 
国 » 配置 Select 语句 


SELECT 语句 (U: 
SELECT [学 引 , 隆 名 ] 性别, [ 民 网 , 旺 中 ] FROM [student] 


Ea 


图 12. 30 “配置 Select 语句 "对话 框 


可 以 生成 附 jp 的 INSERT、UPDATE 和 DELETE 语句 来 更 新 数 撕 潭 . 


生成 INSERT、UPDATE 和 DELETE 语句 (G) 
基于 SELECT 语句 生成 INSERT.。UPDATE 和 DELETE 语句 。 必 须 寺 定 所 有 主键 字 
段 才能 启用 此 运 项 , 


同 使 用 开放 式 并 发 (D) 


修改 UPDATE 和 DELETE 语句 以 检测 各 该 记录 加 载 到 DataSet 中 以 来 数据 库 是 否 更 
改 。 这 有 助 于 防止 并 发 冲突 . 


Cw ] 


图 12. 31 “高 级 SQL 生成 选项 ”对 话 框 


@ 在 出 现 的 对 话 框 中 单 击 “ 测 试 查询 ”按钮 ,出 现 如 图 12. 32 所 示 的 对 话 框 ,表示 查找 成 
功 , 单 击 “ 完 成 ”按钮 。 

这 样 就 在 网 页 中 建立 好 了 SqlDataSourcel 控件 ,并 自动 设置 其 SelectQuery 属性 。 这 些 
SQL 语句 分 别 用 于 SqlDataSourcel 控件 执行 查询 ,插入 、 修 改 和 删除 操作 ,而 且 只 能 执行 这 样 
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SELECT 语句 人: 
SELECT [学 中, 姓名 ], 性别 , [民族 |, 蚂 呈 ] FROM [studend 


图 12. 32 “测试 查询 "对话 框 


的 操作 ,不 能 像 ObjectDataSource 控件 那样 指定 更 加 复杂 的 业务 逻辑 。 

@@ 在 网 页 中 拖 放 一 个 GridView 控件 GridViewl , 单 击 SqlDataSourcel 控件 右上 方 的 智 
能 标记 也] ,在 出 现 的 快捷 菜单 中 将 “选择 数据 源 ” 选 择 为 “SqlDataSourcel”, 并 勾 选 “启动 分 
页 " 复 选 框 ,设置 其 PageSize 属性 为 3。 

这 样 WebForm?7 网 页 的 设计 界面 如 图 12. 33 所 示 , 其 源 视图 代码 的 二 body 二 部 分 如 下 : 


<body> 
<form id= "forml" runat = "server"> 
<asp:SqlDataSource ID = "SqlDataSourcel”runat = "server" 
ConnectionString = "<% $ ConnectionStrings:StudConnectionString %>" 
DeleteCommand = "DELETE FROM [ student] WHERE [学 号 ] = @ 学 号 " 
InsertCommand = "INSERT INTO [student] ([ 学 号 ],[ 姓 名 ],[ 性 别 ], [民族 ], 
[ 班 号 ]) VALUES (@ 学 号 , @ 姓 名 , @ 性 别 ,@ 民 族 , @ 班 号 )" 
SelectCommand = "SELECT [学 号 ],[ 姓 名], [性 别 ], [民族 ],[ 班 号 ] FROM [student]” 
UpdateCommand = "UPDATE [ student] SET [姓名 ] = @ 姓 名 , [性 别 ] = @ 性 别 ， 
[民族 ] = @ 民 族 ，[ 班 号 ] = @ 班 号 WHERE [学 号 ] = @ 学 号 "> 
<DeleteParameters> 
<asp:Parameter Name = "学 号 " TYpe= "String" /> 
</DeleteParameters > 
< InsertParameters> 
<asp:Parameter Name = "学 号 " Type= "String" /> 
<asp:Parameter Name = "姓名 " Type= "String" /> 
<asp:Parameter Name = "性 别 " Type= "String" /> 
<asp:Parameter Name = "民族 " Type= "String" /> 
<asp:Parameter Name = " 班 号 " Type= "String" /> 
</InsertParameters> 
< UpdateParameters> 
<asp:Parameter Name = "姓名 " Type= "String" /> 
<asp:Parameter Name = "性 别 " Type= "String" /> 
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<asp:Parameter Name = "民族 " Type= "String" /> 
<asp:Parameter Name = " 班 号 " Type= "String" /> 
<asp:Parameter Name = "学 号 " TYpe= "String" /> 
</UpdateParameters > 
</asp:SqlDataSource > 
<div> 
<asp:GridView ID= "GridView1”runat = "server" AllowPaging = "True" 
RutoGenerateColumns = "False" DataKeyNames = "学 号 " 
DataSourceID = "SqlDataSourcel" PageSize = "3"> 
<Columns > 
<asp:BoundField DataField = "学 号 " HeaderText = "学 号 " ReadOnly = "True" 
SortExpression = "学 号 " /> 
<asp:BoundField DataField= "姓名 ”HeaderText = "姓名 " 
SortExpression = "姓名 "人 > 
<asp:BoundField DataField = "性 别 " HeaderText = "性 别 " 
SortExpression = "性 别 " /> 
<asp:BoundField DataField = "民族 "HeaderText = "民族 " 
SortExpression = "民族 " /> 
<asp:BoundField DataField = " 班 号 " HeaderText = " 班 号 " 
SortExpression = " 班 号 " /> 
</Columns> 
</asp:GridView> 
</div> 
</form> 
</body> 


在 源 视图 代码 中 ,SqlDataSource 控件 的 ConnectionString 属性 指定 用 于 连接 到 数据 库 的 
连接 字符 串 。 如 果 选 择 将 连接 字符 串 信 息 保存 在 Web. config 配置 文件 中 ,该 值 为 Web. 
config 文件 中 连接 字符 串 设置 的 名 称 ,语法 二 % $ ConnectionStrings:StudConnectionString 
% 志 告诉 数据 源 控件 查看 应 用 的 连接 字符 串 信 息 以 检索 适当 的 信息 。 如 果 选 择 不 将 连接 字符 
串 保 存在 Web. config 文件 中 , 在 这 里 将 用 自己 定义 的 完整 连接 字符 串 代替 二 % $ 
ConnectionStrings: StudConnectionString %>。 

@ 单 击 工具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 ,运行 结果 如 图 12. 34 所 示 。 


abc labc labe abc jabc 
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mt |] 折 分 |。 源 | [4] <asp:sr[>] 
图 12.33 WebForm?7 网 页 设计 界面 图 12.34 WebForm7 网 页 运行 界面 


说 明 : 本 例 中 完全 通过 用 户 操作 生成 SqlDataSourcel 控件 的 相关 属性 ,不 需要 编写 任何 
代码 。 如 果 对 应 的 数据 库 表 没有 设置 主键 , 则 在 第 @ 步 单 击 “ 高 级 ”按钮 后 出 现 的 “高 级 SQL 
生成 选项 ”对 话 框 中 不 能 勾 选 “生成 INSERT、UPDATE 和 DELETE 语句 ” 复 选 框 ,也 就 是 说 
不 能 自动 生成 SqlDataSourcel 控件 的 InsertCommand 属性 、UpadteCommand 属性 和 
DeleteCommand 属性 ,这 样 也 就 不 能 通过 SqlDataSourcel 控件 实现 基础 数据 库 表 中 相应 数据 
的 插入 、 修改 和 删除 操作 。 
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12.5.3 LinkDataSource 控件 


LinkDataSource 控件 位 于 工具 箱 的 “数据 ?类 别 中 ,图 标 为 个 ”tinqDatasource ,对 应 命名 空 
间 System. Web. UI. WebControls 中 的 LinkDataSource 类 。LinkDataSource 控件 支持 通过 
标记 文本 在 ASP.NET 网 页 中 使 用 语言 集成 查询 (LINQ) ,以 从 数据 对 象 中 检索 和 修改 数据 ， 
即 支持 对 数据 对 象 的 查询 .插入 、 删 除 和 更 新 操作 。 

LinkDataSource 控件 的 常见 属性 如 表 12. 35 所 示 , 常 见方 法 如 表 12. 36 所 示 , 常 见 事 件 如 


表 12. 37 所 示 。 


属 性 


表 12.35 LinkDataSource 控件 的 常见 属性 及 其 说 明 
说 明 


Context 
ContextTypeName 
EnableDelete 
Enablelnsert 
EnableUpdate 


为 当前 Web 请 求 获取 与 服务 器 控件 关联 的 HttpContext 对 象 
获取 或 设置 包含 属性 (其 值 包含 要 检索 的 数据 ) 的 类 型 的 名 称 
获取 或 设置 一 个 值 ,该 值 指示 是 否 可 以 通过 LinqDataSource 控件 删除 数据 记录 
获取 或 设置 一 个 值 ,该 值 指示 是 否 可 以 通过 LinqDataSource 控件 插入 数据 记录 
获取 或 设置 一 个 值 ,该 值 指示 是 否 可 以 通过 LinqDataSource 控件 更 新 数据 记录 


GroupBy 获取 或 设置 一 个 值 ,该 值 指定 用 于 对 检索 到 的 数据 进行 分 组 的 属性 
OrderBy 获取 或 设置 一 个 值 ,该 值 指定 用 于 对 检索 到 的 数据 进行 排序 的 字段 
OrderGroupsBy 获取 或 设置 用 于 对 分 组 数据 进行 排序 的 字段 
Select 获取 或 设置 属性 和 计算 值 ,它们 包含 在 检索 到 的 数据 中 
TableName 获取 或 设置 数据 上 下 文 类 中 的 属性 或 字段 的 名 称 ,该 数据 上 下 文 类 表示 一 个 数据 集合 
Where 获取 或 设置 一 个 值 , 该 值 指定 要 将 记录 包含 在 检索 到 的 数据 中 必须 为 真 的 条 件 
表 12.36 ”LinkDataSource 控件 的 常见 方法 及 其 说 明 

方 法 说 明 

DataBind 将 数据 源 绑 定 到 被 调用 的 服务 器 控件 及 其 所 有 子 控件 

Delete 执行 删除 操作 

Insert 执行 插入 操作 

Update 执行 更 新 操作 

表 12.37 LinkDataSource 控件 的 常见 事件 及 其 说 明 
事件 说 明 

ContextCreated 在 创建 上 下 文 类 型 对 象 实例 后 引发 

ContextCreating 在 创建 上 下 文 类 型 对 象 实例 前 引发 

DataBinding 当 服 务 器 控件 绑 定 到 数据 源 时 发 生 

Deleted 完成 删除 操作 后 引发 

Deleting 执行 删除 操作 前 引发 

Inserted 完成 插入 操作 后 引发 

Jnserting 执行 插入 操作 前 引发 

Selected 数据 检索 操作 完成 后 引发 

Selecting 执行 数据 检索 操作 前 引发 

Updated 完成 更 新 操作 后 引发 


执行 更 新 操作 前 引发 


Updating 
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LinkDataSource 控件 的 工作 方式 与 SqlDataSource 控件 一 样 ,也 是 把 在 控件 上 设置 的 属 
性 转换 为 可 以 在 目标 数据 对 象 上 执行 的 查询 。SqlDataSource 控件 可 以 根据 设置 的 属性 生成 
SQL 语句 , LinkDataSource 控件 也 可 以 把 设置 的 属性 转换 为 有 效 的 LINQ, 也 就 是 说 ， 
LinqDataSource 控件 使 用 LINQ to SQL 来 自动 生成 数据 命令 ,有 关 LINQ 和 LINQ to SQL 
的 内 容 将 在 下 一 章 介绍 。 

在 实际 应 用 中 ,用 户 可 以 利用 LinkDataSource 控件 的 配置 数据 源 向 导 来 选择 要 查询 的 数 
据 对 象 ,可 选 的 数据 对 象 称 为 上 下 文 对 象 (DataContext) 。DataContext 表示 LINQ to SQL 框 
架 的 主人 口 点 , 它 是 通过 数据 库 连 接 映射 的 所 有 实体 的 源 ,会 跟踪 用 户 对 所 有 检索 到 的 实体 所 
做 的 更 改 , 并 且 保 留 一 个 “标识 缓存 ”, 该 缓存 确保 使 用 同一 对 象 实例 表示 多 次 检索 到 的 实体 。 

Visual Studio 提供 了 用 户 Object Relation(O/R) 映 射 器 , 它 可 以 快速 地 将 基于 SQL 的 数 
据 源 映射 为 .NET Framework 的 CLR 元 素 , 之 后 就 可 以 使 用 LINQ 查询 了 。 

下 面 以 SQL Server 数据 库 Stud 中 的 表 student 为 目标 数据 说 明 利 用 O/R 映射 器 创建 上 
下 文 对 象 的 步骤 。 

QO@ 打开 chl2 网 站 ,选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -ch12” 对 话 框 ,在 中 间 列 表 
中 选择 "LINQ to SQL 类 ”, 保持 默认 文件 名 DataClasses. dbml, 如 图 12. 35 所 示 , 单 击 “ 添 加 ” 
按钮 。 通 常 ,系统 会 自动 将 该 文件 保存 在 App_Code 目录 中 。 


加 搜索 已 安装 模板 (Ctr|+ 日 
Visual cr ~ 类 型 Visual C# 


vomor 


siveright 10 Javascript visual cr 

siveright EF Visual ce 
贺 SQL Server Compact 4.0 本 .Visual C# 
图 SQL server 了 IE 库 Visual ce 
六 StyleSheetLESS Visual Ce 


DataClasses.dbml 


图 12.35 “添加 新 项 -ch12” 对 话 框 


@ 出 现 创建 DataClasses. dbml 的 界面 ,如 图 12. 36 所 示 。 如 果 没 有 出 现 该 界面 ,用 户 可 
以 在 解决 方案 资源 管理 器 中 双击 DataClasses. dbml 文件 名 。 如 果 没 有 出 现 服务 器 资源 管理 
器 ,可 以 单 击 中 部 的 “服务 器 资源 管理 器 ? 超 链接 。 如 果 服 务 器 资源 管理 器 中 的 数据 连接 部 分 
为 空 ,可 以 右 击 它 ,在 出 现 的 快捷 菜单 中 选择 “添加 连接 ”命令 来 添加 一 个 连接 (其 操作 与 
SqlDataSource 控件 的 建立 连接 过 程 相同 ) 。 

@ 在 服务 器 资源 管理 器 中 选择 Stud 数据 库 中 的 student 表 , 将 其 拖 放 到 对 象 关 系 设计 器 
中 ,设计 器 将 显示 其 结构 ,并 自动 创建 一 个 对 应 的 实体 类 student, 如 图 12. 37 所 示 。 

@ 单 击 工具 栏 中 的 国 按 钮 保存 文件 。 
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DY localhost 51155 - Microsoft Visual sudio( 六 理 ) 侠 过 启动 (Ctl+Q) pe Hi 
文 (HP 编 岛 (E) 视图 (V) 网 站 (S) 生成 (8) 调式 ID) EMM) 工具 (D WS) 分析 (N) 害 D(W) 帮助 (H) 
昌 -O 间 - 面 贞 中 | 了 -CS - ImiemetEplorer- Debug - 画 - 


慑 务 示 学 因 介 理 本 
x 常备 辐 
SharePoint 连接 1 搜索 解决 广安 资源 合理 器 (Ctrl+) Pp- 
时 服 各 江 a 
4 cepc 天 9 刍 关系 慨 计 各 可 L 在 代码 中 实现 同和 “ochost S1155" (1 


培训 列表 
0 个 要 于 | 和 0 个 清香。 利 雪 恒 误 FI 
中 国 视 可 “| 府 行 到 天 上 did 
上 大 让 id 程 日 杂项 
ra 3 DAASP NET\chi2App 
大 月 义 启 文 必 名 DataClasses.dbml 
b 国 类 y Em MstinqTosQLGenerato 
上 国 宪 ? 生 
工具 要 | 服务 器 训 天 管理 屋 | ‘ » 


通过 梅 项 从 
这 管理 器 中 拖 到 此 设 
计 男 面 上 来 创建 方法 。 


图 12.37 创建 的 上 下 文 对 象 


student 实体 类 的 部 分 代码 如 下 : 


public partial class student : INotifyPropertyChanging, INotifyPropertyChanged 


{ 


private string _ 学 号 ; 

private string _ 姓 名 ; 

private string 性 别 ; 

private string _ 民 族 ; 

private string _ 班 号 ; 

[global: :System. Data. Linq. Mapping. ColumnRttribute(Storage = "_ 学 号 "， 
DbType= "Char(5) NOT NULL", CanBeNull = false, IsPrimaryKey= true)] 


public string 学 号 // 学 号 属性 
{ get 

{ ”return this. 学 号 ; } 

set 


下 if ((this._ 学 号 != value)) 
{ ”this. On 学 号 Changing(value); 
this. SendPropertYyChanging() 
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this. 学 号 = value; 
this. SendpPropertyChanged( "学 号 "); 
this. On 学 号 Changed( ); 


} 


上 述 student 类 被 映射 成 一 个 表 , 对 应 数据 库 中 的 student 表 。 该 类 中 定义 了 5 个 属性 ， 
对 应 表 中 的 5 个 字段 ,其 中 ,” 学 号 ?字段 是 主键 。 

在 建立 了 上 下 文 对 象 后 ,访问 其 数据 就 很 简单 了 。 下 面 通 过 一 个 示例 说 明 如 何 使 用 
LinkDataSource 控件 实现 对 数据 对 象 的 查询 。 

【 例 12.17】 设计 一 个 通过 LinkDataSource 控件 来 访问 student 表 ,并 采用 GridView 控 
件 显示 所 有 记录 的 网 页 WebForm8。 

解 : 其 步骤 如 下 。 

@ 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm8 空 网 页 。 

@ 切换 到 设计 视图 ,从 工具 箱 的 "数据 ?类 别 中 将 LinkDataSource 控件 拖 动 到 网 页 上 。 
如 果 智 能 标记 面板 没有 显示 , 单 击 LinkDataSourcel 控件 右上 方 的 智能 标记 站] . 

@ 在 “LinkDataSource 任务 ”列表 中 选择 “配置 数据 源 " 命 令 将 显示 “配置 数据 源 - 
LinqDataSourcel” 向 导 ,出 现 *“ 选 择 上 下 文 对 象 "对 话 框 ,选择 “DataClassesDataContext” 上 下 
文 对 象 ,如 图 12. 38 所 示 ,然后 单 击 * 下 一 步 ?按钮 。 


Cr sm |) Eee 


图 12. 38 “选择 上 下 文 对 象 "对 话 框 


@ 出 现 “ 配 置 数据 选择 "对话 框 ,选择 “student” 表 ,选择 字段 ,如 图 12. 39 所 示 , 然 后 单 击 
“高 级 ”按钮 。 

@ 在 出 现 的 “高 级 选项 ”对 话 框 中 选择 所 有 选项 ,如 图 12. 40 所 示 。 然 后 单 击 “ 确 定 ” 按 钮 返 
回 到 “配置 数据 选择 ”对 话 框 ,再 单 击 “ 完 成 按钮。 从 网 页 源 视图 代码 中 看 到 LinqDataSourcel 的 
代码 如 下 : 
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12. 39 “配置 数据 选择 "对话 框 


<asp:LinqDataSource ID= "LingDataSourcel" runat = "server" 
ContextTypeName = " DataClassesDataContext" 
EnableDelete = "True" EnableInsert = "True" EnableUpdate = "True" 
EntityTypeName = "" 
Select = "new (学 号 , 姓名 , 性 别 ,， 民族, 班 号 )” 
TableName = "student"> 
</asp:LingDataSource> 
在 上 述 代 码 中 , LinqDataSourcel 控件 的 ContextTypeName 属性 指定 上 下 文 对 象 为 
DataClassesDataContext,TableName 属性 指定 查询 的 表 名 为 student, Select 属性 指定 字段 
列表 。 
@ 在 网 页 中 放 入 一 个 GridView 控件 GridView1, 通 过 “GridView 任务 ”列表 设置 它 的 
“选择 数据 源 ” 为 LinkDataSourcel 。 
@ 单 击 工具 栏 中 的 上 Internet Explorer 按钮 运行 本 网 页 ,运行 结果 如 图 12. 41 所 示 。 


Em 一 


图 12. 40 “高 级 选项 "对话 框 图 12.41 WebForm8 网 页 运行 界面 
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12.6 数据 绑 定 控件 


12.6.1 数据 绑 定 控件 概述 


数据 绑 定 就 是 把 数据 连接 到 网 页 的 过 程 , 在 数据 绑 定 后 ,可 以 通过 网 页 界面 来 操作 数据 库 
中 的 数据 。 

数据 绑 定 控件 将 数据 以 标记 的 形式 呈现 给 请 求 数据 的 浏览 器 。 数 据 绑 定 控件 可 以 绑 定 到 
数据 源 控件 ,并 自动 在 页 请 求生 命 周期 的 适当 时 间 获 取 数 据 。 数 据 绑 定 控 件 可 以 利用 数据 源 
控件 提供 的 功能 ,包括 排序 分 页 、 缓 存 . 筛选 .更 新 ` 删 除 和 插入。 数据 绑 定 控件 通过 其 
DataSourceID 属性 连接 到 数据 源 控件 。 

ASP.NET 包括 的 数据 绑 定 控件 如 表 12. 38 所 示 。 

表 12.38 ASP.NET 包 括 的 数据 绑 定 控件 及 其 说 明 

数据 绑 定 控件 说 明 


列表 控件 以 各 种 列表 形式 呈现 数据 。 列表 控 件 包 括 BulletedList、 CheckBoxList、 DropDownList、 
ListBox 和 RadioButtonList 等 标准 服务 器 控件 

GridView 以 表 的 形式 显示 数据 ,并 支持 在 不 编写 代码 的 情况 下 对 数据 进行 编辑 ,更 新 .排序 和 分 页 

DataList 以 表 的 形式 呈现 数据 。 每 一 项 都 使 用 用 户 定义 的 项 模板 呈现 

DetailsView ”以 表格 布局 一 次 显示 一 个 记录 ,并 允许 编辑 、 删 除 和 插入 记录 ,还 可 以 翻阅 多 个 记录 

FormView 与 DetailsView 控件 类 似 ,但 允许 用 户 为 每 一 个 记录 定义 一 种 自动 格式 的 布局 。 对 于 单个 
记录 ,FormView 控件 与 DataList 控件 类 似 

AdRotator 将 广告 作为 图 像 呈 现在 网 页 上 ,用 户 可 以 通过 单 击 该 图 像 转 到 与 广告 关联 的 URL 

Menu 在 可 以 包括 子 菜单 的 分 层 动态 菜单 中 呈现 数据 

Repeater 以 列表 的 形式 呈现 数据 。 每 一 项 都 使 用 用 户 定义 的 项 模板 呈现 

TreeView 以 可 展开 结 点 的 分 层 树 的 形式 呈现 数据 


12.6.2 列表 控件 的 绑 定 


在 列表 控件 中 可 以 显示 一 组 数据 ,可 以 和 数据 库 表 进行 绑 定 , 称 为 复合 绑 定 。 列 表 控件 绑 
定 的 基本 方法 是 通过 DataSource 属性 指定 绑 定 的 数据 源 , DataTextField 属性 指定 要 显示 的 
表 字 段 .然后 调用 DataBind 方法 。 

例如 设计 一 个 网 页 ,其 中 只 有 一 个 HTML 文本 * 班 号 :” 和 一 个 下 拉 列 表 控件 DropDownListl， 
在 该 网 页 上 设计 如 下 事件 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
{ string mystr; 
mystr = System. Configuration.ConfigurationManager. 
ConnectionStrings["myconnstring"]. ToString(); 
SqlConnection myconn = new SqlConnection(); 
myconn. ConnectionString = mystr; 
myconn. Open( ); 
DataSet myds = new DataSet(); 
SqlDataAdapter myda = new SqlDataAdapter("SELECT distinct 班 号 FROM student", 
myconn); 
myda. Fill(myds, "student"); 
DropDownList1. DataSource = myds.Tables["student"]; 
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DropDownList1. DataTextField = " 班 号 "; 
DropDownList1. DataBind( ); // 数 据 绑 定 
DropDownList1. Items. Insert(0," 所 有 选项 "); ” // 插 入 作为 第 一 项 


myconn. Close( ) ; 
} 


单 击 工 具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,运行 ex 
结果 如 图 12. 42 所 示 。DropDownListl 控件 中 有 3 个 选项 ，|( 辐 国 人 @we/eononsn5 Pp-o 
后 两 个 来 自 student 表 , 第 一 项 是 通过 Insert 方法 插入 的 。 Doctont * 

注意 : 在 运行 网 页 时 ,DropDownListl 控件 中 必须 有 一 5: EE 
项 被 选择 (默认 为 第 一 项 )。 有 时 不 需要 选择 任何 内 容 , 可 以 
采用 本 例 的 设计 方式 ,在 下 拉 列 表 控 件 添加 “所 有 选项 ”, 然 
后 通过 DropDownList 控件 的 SelectedValue 属性 进行 判断 ， 图 12. 42 网 页 中 的 下 拉 列 表 控 件 
并 做 相应 的 处 理 。 


12.6.3 GridView 控件 


GridView 控件 称 为 列表 视图 控件 ,在 工具 箱 的 “数据 ?类 别 中 ,其 图 标 为 亩 Gridview 。 该 
控件 用 于 在 一 个 列表 中 显示 数据 源 的 值 ,其 中 每 列表 示 一 个 字段 ,每 行 表 示 一 条 记录 。 它 允许 
用 户 选 择 和 编辑 这 些 项 以 及 对 它们 进行 排序 等 。 对 应 的 GridView 类 位 于 System. Web. UL 
WebControls 命名 空间 。 

1 GridView 控件 的 常用 属性 ,方法 和 事件 

GridView 控件 的 常用 属性 及 其 说 明 如 表 12. 39 所 示 , 常 用 方法 及 其 说 明 如 表 12. 40 所 
示 , 常 用 事件 及 其 说 明 如 表 12. 41 所 示 。 


表 12.39 GridView 控件 的 常用 属性 及 其 说 明 


属 性 说 明 

AllowPaging 获取 或 设置 一 个 值 ,该 值 指示 是 否 启 用 分 页 功能 

AllowSorting 获取 或 设置 一 个 值 ,该 值 指示 是 否 启 用 排序 功能 

AutoGenerateColumns ”获取 或 设置 一 个 值 ,该 值 指示 是 否 为 数据 源 中 的 每 个 字段 自动 创建 绑 定 字段 

Columns 获取 表示 GridView 控件 中 列 字 段 的 DataControlField 对 象 的 集合 

DataKeyNames 获取 或 设置 一 个 数组 ,该 数组 包含 了 显示 在 GridView 控件 中 的 项 的 主键 字段 的 
名 称 

DataKeys 获取 一 个 DataKey 对 象 集合 ,这 些 对 象 表示 GridView 控件 中 的 每 一 行 的 数据 键 值 

DataMember 当 数 据 源 包 含 多 个 不 同 的 数据 项 列表 时 ,获取 或 设置 数据 绑 定 控件 绑 定 到 的 数据 
列表 的 名 称 

DataSource 获取 或 设置 对 象 ,数据 绑 定 控 件 从 该 对 象 中 检索 其 数据 项 列表 

DataSourcelD 获取 或 设置 控件 的 ID 

GridLines 获取 或 设置 GridView 控件 的 网 格 线 样式 

PageCount 获取 在 GridView 控件 中 显示 数据 源 记录 所 需 的 页 数 

PageIndex 获取 或 设置 当前 显示 页 的 索引 

PaacrSettiags 获取 对 PagerSettings 对 象 的 引用 .使 用 该 对 象 可 以 设置 GridView 控件 中 的 页 导 
航 按钮 的 属性 

PagerStyle 获取 对 TableltemStyle 对 象 的 引用 ,使 用 该 对 象 可 以 设置 GridView 控件 中 的 页 导 


航行 的 外 观 


属 性 
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续 表 


说 明 


PagerTemplate 
PageSize 

Rows 
SelectedDataKey 
SelectedIndex 
SelectedRow 
SelectedValue 
SortDirection 


SortExpression 


获取 或 设置 GridView 控件 中 页 导航 行 的 自 定义 内 容 

获取 或 设置 GridView 控件 在 每 页 上 所 显示 的 记录 的 数目 

获取 表示 GridView 控件 中 数据 行 的 GridViewRow 对 象 的 集合 
获取 DataKey 对 象 ,该 对 象 包含 GridView 控件 中 选中 行 的 数据 键 值 
获取 或 设置 GridView 控件 中 的 选中 行 的 索引 

获取 对 GridViewRow 对 象 的 引用 ,该 对 象 表示 控件 中 的 选中 行 
获取 GridView 控件 中 选中 行 的 数据 键 值 

获取 正在 排序 的 列 的 排序 方向 

获取 与 正在 排序 的 列 关联 的 排序 表达 式 


表 12.40 GridView 控件 的 常用 方法 及 其 说 明 


方 法 说 明 
DataBind 将 数据 源 绑 定 到 GridView 控件 
DeleteRow 从 数据 源 中 删除 位 于 指定 索引 位 置 的 记录 
Sort 根据 指定 的 排序 表达 式 和 方向 对 GridView 控件 进行 排序 
UpdateRow 使 用 行 的 字段 值 更 新 位 于 指定 行 索引 位 置 的 记录 
表 12.41 GridView 控件 的 常用 方法 及 其 说 明 
事件 说 明 
DataBinding 当 服 务 器 控件 绑 定 到 数据 源 时 引发 
DataBound 在 服务 器 控件 绑 定 到 数据 源 后 引发 


PageIndexChanged 
PageIndexChanging 
RowCommand 
RowDataBound 
RowDeleted 
RowDeleting 
RowEditing 
RowUpdated 
RowUpdating 
SelectedlndexChanged 
SelectedIndexChanging 


在 单 击 某 一 页 导航 按钮 时 ,但 在 GridView 控件 处 理 分 页 操作 之 后 引发 

在 单 击 某 一 页 导航 按钮 时 ,但 在 GridView 控件 处 理 分 页 操作 之 前 引发 

当 单 击 GridView 控件 中 的 按钮 时 引发 

在 GridView 控件 中 将 数据 行 绑 定 到 数据 时 引发 

在 单 击 某 一 行 的 “删除 ”按钮 时 ,但 在 GridView 控件 删除 该 行 之 后 引发 

在 单 击 某 一 行 的 “删除 "按钮 时 ,但 在 GridView 控件 删除 该 行 之 前 引发 

在 单 击 某 一 行 的 “编辑 ”按钮 以 后 ,GridView 控件 进入 编辑 模式 之 前 引发 

在 单 击 某 一 行 的 “更 新 "按钮 ,并且 GridView 控件 对 该 行进 行 更 新 之 后 引发 
在 单 击 某 一 行 的 “更 新 "按钮 以 后 ,GridView 控件 对 该 行进 行 更 新 之 前 引发 

在 单 击 某 一 行 的 “选择 ”按钮 ,GridView 控件 对 相应 的 选择 操作 进行 处 理 之 后 引发 
在 单 击 某 一 行 的 “选择 ”按钮 以 后 ,GridView 控件 对 相应 的 选择 操作 进行 处 理 之 
前 引发 


Sorted 在 单 击 用 于 列 排 序 的 超 链接 时 ,但 在 GridView 控件 对 相应 的 排序 操作 进行 处 理 
之 后 引发 
Sorting 在 单 击 用 于 列 排 序 的 超 链 接 时 ,但 在 GridView 控件 对 相应 的 排序 操作 进行 处 理 
之 前 引发 
下 面 主要 介绍 几 个 常用 的 属性 。 


(1) PagerSettings 属性 


使 用 PagerSettings 


属性 控制 GridView 控件 中 页 导航 行 的 设置 。 它 是 一 个 PagerSettings 对 
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象 的 引用 。 
如 果 想 要 对 分 页 编码 进行 设置 ( 需 将 AllowPaging 属性 设置 为 True) ,可 以 在 HTML 代 
码 中 为 GridView 控件 添加 分 页 导航 条 形式 代码 。 也 就 是 启用 GridView 的 PagerSettings 属 
性 ,在 PagerSettings 属性 中 可 以 根据 需要 设置 Mode 的 值 ,从 而 实现 分 页 编码 的 显示 效果 。 
PagerSettings 属性 的 Mode 有 下 面 4 种 取 值 。 
。 NextPrevious: 上 一 页 按钮 和 下 一 页 按钮 。 
。 NextPreviousFirstLast: 上 一 页 按钮 .下 一 页 按钮 .第 一 页 按钮 和 最 后 一 页 按钮 。 
。 Numeric: 可 直接 访问 页 面 的 带 编 号 的 链接 按钮 。 
。 NumericFirstLast: 带 编号 的 链接 按钮 .第 一 个 链接 按钮 和 最 后 一 个 链接 按钮 。 
在 将 Mode 属性 设置 为 NextPrevious、NextPreviousFirstLast 或 NumericFirstLast 值 时 ， 
用 户 可 以 通过 设置 PagerSettings 属性 的 以 下 属性 来 自 定义 非 数 字 按 钮 的 文字 。 
。 FirstPageText: 第 一 页 按钮 的 文字 。 
。 PreviousPageText: 上 一 页 按钮 的 文字 。 
。 NextPageText: 下 一 页 按钮 的 文字 。 
。 LastPageText: 最 后 一 页 按钮 的 文字 。 
例如 ,在 网 页 中 有 一 个 GridViewl 控件 ,其 数据 源 的 连接 字符 串 为 例 12. 16 创建 的 
StudConnectionString ,将 PageSize 属性 设置 为 2. 设置 其 PagerSettings 属性 如 下 : 


<PagerSettings 
Mode = "NextPreviousFirstLast" 
FirstPageText = "首页 " 
LastPageText = " 末 页 "> 
</PagerSettings > 


该 网 页 的 各 页 面 的 显示 结果 如 图 12. 43 所 示 。 


第 1 页 的 显示 结 第 2 页 的 显示 结 最 后 一 页 的 显示 结 


QO 是 ntpVlocalhost5115' 启 @ | @ napyV/localhostslls P 
x 


大 localhost 筷 localhost x 
学 号 | 姓名 性 别 | 民族 | 班 号 学 号 姓名 | 性 别 | 民族 | 班 号 
1 _ | 王储 女 | 汉族 09001 | 3 _ | 李兵 男 | 满族 (09001 
”| 区 琴 女 | 又 族 |09002 5 “| 索 军 勇 | 汉族 |09001| 
> 未 页 首页 《> 本 页 


图 12. 43 ”设置 PagerSettings 属性 后 GridView 控件 的 显示 结果 


用 户 也 可 以 通过 设置 PagerSettings 属性 的 以 下 属性 为 非 数字 按钮 显示 图 像 。 

。 FirstPageImageUrl: 为 第 一 页 按钮 显示 的 图 像 的 URL。 

。 PreviousPageImageUrl: 为 上 一 页 按钮 显示 的 图 像 的 URL。 

。 NextPageImageUrl: 为 下 一 页 按钮 显示 的 图 像 的 URL。 

。 LastPageImageUrl: 为 最 后 一 页 按钮 显示 的 图 像 的 URL。 

(2) PageSize、PageCount 和 PageIndex 属性 

PageSize 属性 获取 或 设置 一 个 页 面 中 显示 的 记录 个 数 。PageCount 属性 获取 或 设置 总 的 
页 数 ,PageIndex 获取 或 设置 当前 的 页 号 。 正 确 地 使 用 这 些 属性 可 以 实现 分 页 功能 。 
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(3) AutoGenerateColumns 属性 

该 属性 获取 或 设置 网 页 运行 时 是 否 基于 关联 的 数据 源 自 动 生 成 列 , 其 默认 值 为 True, 也 
就 是 说 ,一 旦 指定 了 GridView 控件 的 数据 源 , 便 自动 生成 相应 的 列 。 在 有 些 情 况 下 不 希望 自 
动 生成 列 , 而 是 通过 “GridView 任务 "列表 的 “编辑 列 ? 命 令 来 设置 相关 的 列 ,此 时 要 将 
AutoGenerateColumns 属性 设 为 False。 

(4) DataKeyNames 和 DataKeys 属性 

DataKeyNames 属性 是 一 个 字符 串 数组 , 指定 表示 数据 源 主键 的 字段 。 当 设置 了 
DataKeyNames 属性 时 ,GridView 控件 自动 为 该 控件 中 的 每 一 行 创建 一 个 DataKey 对 象 。 
DataKey 对 象 包含 在 DataKeyNames 属性 中 指定 的 字段 的 值 。DataKey 对 象 随后 被 添加 到 控 
件 的 DataKeys 集合 中 。 使 用 DataKeys 属性 检索 GridView 控件 中 特定 数据 行 的 DataKey 对 
象 。 这 提供 了 一 种 访问 每 个 行 的 主键 的 便捷 方法 。 例 如 : 


GridView1. DataKeyNames = new string[] {" 学 号 "}; 


TextBoxl. Text = GridViewl.DataKeys[0].Value.ToString(); 


GridView 控件 的 DataKeyNames 属性 可 被 设置 为 绑 定 到 GridView 的 数据 的 主键 列 名 ， 
如 果 设 置 了 该 属性 , GridView 控件 将 自动 跟踪 每 行 的 主键 列 值 。 当 绑 定 数据 源 控件 到 
GridView 控件 时 ,该 属性 自动 被 设置 为 数据 源 控件 返回 的 主键 列 。 

(5) Rows 属性 

该 属性 获取 表示 GridView 控件 中 数据 行 的 GridViewRow 对 象 的 集合 ,有 关 GridViewRow 
类 的 内 容 将 在 后 面 进一步 介绍 。 

通过 使 用 GridViewRow 对 象 的 Cells 属性 可 以 访问 一 行 的 单独 单元 格 。 如 果 某 个 单元 
格 包 含 其 他 控件 , 则 通过 使 用 单元 格 的 Controls 集合 可 以 从 单元 格 检 索 控件 。 如 果 控 件 指定 
了 ID, 还 可 以 使 用 单元 格 的 FindControl 方法 来 查找 该 控件 。 

若 要 从 BoundField 字段 列 或 自动 生成 的 字段 列 检索 字段 值 , 需 使 用 单元 格 的 Text 属性 。 
若 要 从 将 字段 值 绑 定 到 控件 的 其 他 字段 列 类 型 检索 字段 值 , 需 先 从 相应 的 单元 格 检索 控件 , 然 
后 访问 该 控件 的 相应 属性 。 

例如 ,以 下 代码 显示 第 2 行 的 姓名 : 

TextBoxl. Text = GridView1. Rows[1].Cells[1].Text; // 第 2 个 单元 格 为 姓名 ,索引 均 从 0 开始 


2. 绑 定 到 数据 
GridView 控件 可 绑 定 到 数据 源 控件 (如 SqlDataSource 等 ) 以 及 实现 System. Collections. 
IEnumerable 接口 的 任何 数据 源 ( 如 System. Data. DataView System. Collections, ArrayList 
或 System. Collections. Hashtable) ,使 用 以 下 方法 之 一 将 GridView 控件 绑 定 到 适当 的 数据 源 
类 型 ; 
。 若 要 绑 定 到 某 个 数据 源 控件 , 需 将 GridView 控件 的 ID 属性 设置 为 该 数据 源 控件 的 
ID 值 。GridView 控件 自动 绑 定 到 指定 的 数据 源 控 件 , 并 且 可 利用 该 数据 源 控件 的 功 
能 来 执行 排序 .更 新 .删除 和 分 页 功能 。 这 是 绑 定 到 数据 的 首选 方法 。 
。 若 要 绑 定 到 某 个 实现 System. Collections. IEnumerable 接口 的 数据 源 , 需 以 编程 方式 
将 GridView 控件 的 DataSource 属性 设置 为 该 数据 源 ,然后 调用 DataBind 方法 。 当 
使 用 此 方法 时 ,GridView 控件 不 提供 内 置 的 排序 .更 新 删除 和 分 页 功能 ,需要 使 用 适 
当 的 事件 提供 此 功能 。 
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这 里 主要 介绍 第 一 种 方法 ,下 面 通过 一 个 例子 进行 说 明 。 
【 例 12.18】 设计 一 个 通过 GridView 控件 显示 student 表 记 录 的 网 页 WebForm9。 


解 : 其 步骤 如 下 。 


@ 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm9 空 网 页 。 
@ 向 其 中 拖 放 一 个 GridView 控件 GridView1。 
@ 在 "GridView 任务 ”列表 中 选择 “新 建 数据 源 ” 命 令 , 如 图 12. 44 所 示 。 


ene a 


<form#form1> 


<asp:GridView#Gridview1> |»] 


12.44 “GridView 任务 ”列表 


@ 出 现 如 图 12. 45 所 示 的 “选择 数据 源 类 型 ”对话 框 ,选中 “数据 库 ”, 保 持 默 认 的 名 称 


SqlDataSourcel, 单 击 “ 确 定 ” 按 钮 。 


连接 到 ADOJNET 支持 的 任何 SQL 数据 库 ， 如 Microsoft SQL Server、Oradle 或 OLEDB。 


图 12.45 “选择 数据 源 类 型 "对 话 框 


@ 按照 前 面 建立 SqlDataSource 控件 数据 源 的 方式 ,在 这 里 指定 其 数据 源 为 Stud 数据 库 
的 student 表 .将 GridViewl 控件 的 PageSize 属性 设置 为 3。 此 时 设置 的 “GridView 任务 ” 列 


表 如 图 12. 46 所 示 , 在 其 中 色 选 相关 选项 
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idview# Gr 


编辑 删除 选择 abc jabc labc labc 
编辑 删除 选择 abc |abc |abc labc 
E 开除 “选择 abc |abe |abe |abe 


5 设计 |m 拆 分 |。 源 | [4][<html>][<body>|[<formsforml>| <asp:GridViews#GridView1> |» 


图 12.46 “GridView 任务 ”列表 


在 上 述 操作 后 ,GridViewl 控件 的 相关 属性 会 自动 更 改 , 如 AllowPaging 属性 会 自动 设置 
为 True 等 。 用 户 可 以 在 “GridView 任务 ”列表 中 选择 “编辑 列 " 命 令 设置 相关 的 列 属性 ,还 可 
以 选择 “自动 套用 格式 "命令 设置 GridViewl 控件 的 外 观 等 。 

最 后 生成 的 WebForm9 网 页 源 视图 代码 的 二 body 二 部 分 如 下 : 


<body> 
<form id= "forml" runat = "server"> 
<asp:GridView ID = "GridViewl" runat = "server" AllowPaging= "True" 
AllowSorting = "True" AutoGenerateColumns = "False" DataKeyNames = "学 号 " 
DataSourceID = "SqlDataSourcel" PageSize = "3"> 
<Columns> 
<asp:CommandField ShowDeleteButton = "True”ShowEditButton = "True" 
ShowSelectButton = "True" /> 
<asp:BoundField DataField = "学 号 " HeaderText = "学 号 " ReadOnly = "True" 
SortExpression = "学 号 " /> 
<asp:BoundField DataField= "姓名 ”HeaderText = "姓名 " 
SortExpression= "姓名 " /> 
<asp:BoundField DataField= "性 别 ”HeaderText = "性 别 " 
SortExpression= "性 别 ”/> 
<asp:BoundField DataField= "民族 ”HeaderText = "民族 " 
SortExpression= "民族 ”人 > 
<asp:BoundField DataField= " 班 号 ” HeaderText = " 班 号 " 
SortExpression=" 班 号 " /> 
</Columns > 
</asp:GridView> 
<“asp:SqlDataSource ID = "SqlDataSourcel" runat = "server" 
<- 这 部 分 代码 与 例 12. 16 中 SqlDataSourcel 的 源 视图 代码 相同 -> 
</asp:SqlDataSource > 
</form> 
</body > 
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从 中 可 以 看 到 , GridViewl 控件 的 二 Columns 二 元素 用 于 表示 字段 列表 ,第 一 个 字段 是 
CommandField 类 型 的 字段 , 即 命令 字段 ,包含 “编辑 "“ 删 除 ” 和" 选择? 超 链接 ; 其 他 为 
BoundField 类 型 的 字段 , 即 绑 定 字段 ,分 别 与 相应 数 
据 源 的 表 字 段 绑 定 。 

@@ 单 击 工 具 栏 中 的 IntemetExplorer 按钮 运行 本 
网 页 ,其 结果 如 图 12. 47 所 示 , 用 户 可 以 单 击 “编辑 ”、 
“删除 ”和 “选择 ” 超 链接 实现 相应 的 功能 ,也 可 以 单 击 
“1” 或 “2” 超 链接 显示 相应 的 页 面 记 录 。 

@ 返回 到 网 页 设计 界面 ,通过 “格式 | 字体 "命令 
修改 GridView1l 控件 的 字体 。 在 “GridView 任务 ” 列 
表 中 选择 “编辑 列 " 命 令 , 单 击 “ 选 定 的 字段 ”列表 中 的 
CommandField 项 ,修改 其 ButtonType 属性 为 Button( 默 认为 Link) ,如 图 12. 48 所 示 , 修 改 其 
ControlStyle 属性 如 图 12. 49 所 示 。 


图 12.47 WebForm9 网 页 运行 结果 


图 12.48 修改 CommandField 字段 的 ButtonType 属性 


单 击 工具 栏 中 的 Pp Internet Explorer 按钮 运行 本 网 页 ,其 结果 如 图 12. 50 所 示 。 

注意 在 运行 时 GridViewl 控件 的 每 个 绑 定 字 段 标题 呈现 超 链接 。 Wk 从 前 面 的 源 视图 
代码 中 看 到 GridViewl 控件 中 每 个 绑 定 字段 都 有 SortExpression 属性 , 它 指出 排序 的 字段， 
所 以 在 运行 时 单 击 GridView1 近 什 让 于 不 训 志 二 区 的 所 通 霹 拓 交 ,出 必 失 为 SortExpression 
属性 指出 的 字段 进行 排序 。 图 12. 51 所 示 的 是 单 击 “ 班 号 ”标题 超 链接 后 的 显示 结果 ,3 个 
09001 班 的 学 生 记录 显示 在 第 一 页 中 。 

说 明 : 本 例 没有 编写 一 行 代码 ,都 是 通过 用 户 操作 来 实现 网 页 设计 的 ,查看 源 代码 有 下 面 
几 点 说 明 。 

@ 自动 设置 GridViewl 控件 的 SqlDataSource ID 属性 为 “SqlDataSourcel”。 
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图 12.49 修改 CommandField 字段 的 ControlStyle 属性 


所 htp//ocalhostS1155Wel D> © ee ted | 


| 你 htpy/localhost51155/WebFc P ~ © | Ye Ee 
Elocalhost x @ localhost x 
班 号 [ 隆 到 玛 别 区 迁 查 且 
| 上 编辑 | | 开除 | | 渤 手 由 | | 王 华 | 女 | 汉族 (09001 1 “| 王 华 | 女 lo9001| 
编辑 | | 删除 | | 选择 对 丽 女 “| 汉族 李兵 | 男 “| 满 调 09001 
编辑 | | 种 除 | | 选择 李兵 男 | 满族 09001 张 军 | 男 | 汉族 | 
12 
图 12. 50 ”修改 后 WebForm9 网 页 的 运行 结果 图 12.51 按 班 号 排序 后 的 运行 结果 


@ SqlDataSourcel 控件 用 于 操作 Stud 数据 库 的 student 表 。 

@ 当 GridView 控件 绑 定 到 数据 源 控 件 SqlDataSourcel 时 ,DataKeyNames 属性 自动 被 
设置 为 数据 源 控件 返回 的 主键 列 ( 这 里 为 “学 号 ”), GridView 控件 中 的 每 行 都 是 以 
DataKeyNames 属性 值 为 关键 字 。 

四 如 果 不 指定 对 应 SqlDataSource 控件 的 UpdateCommand、InsertCommand 和 
DeleteCommand 属性 , 则 GridView 控件 不 支持 更 新 、 插 入 和 删除 操作 。 本 例 通过 操作 自动 设 
置 了 这 些 属性 。 

3. 基本 数据 操作 

GridView 控件 提供 了 很 多 内 置 功 能 .这些 功能 使 得 用 户 可 以 对 控件 中 的 项 进行 排序 .更 
新 、 删 除 、 选 择 和 分 页 。 当 GridView 控件 绑 定 到 某 个 数据 源 控 件 时 ,GridView 控件 可 利用 该 
数据 源 控件 的 功能 并 提供 自动 排序 、 更 新 和 删除 功能 。GridView 控件 也 可 以 为 指定 的 数据 源 
提供 对 排序 、 更 新 和 删除 的 支持 ,但 必须 提供 一 个 适当 的 事件 处 理 程序 ,其 中 包含 对 这 些 操作 
的 实现 。 
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(1) 删除 操作 

当 用 户 单 击 “ 删 除 ”按钮 时 ,网 页 被 刷新 , 且 其 “删除 ”按钮 被 单 击 的 那 条 记录 将 消失 。 

删除 操作 的 工作 原理 : 用 户 单 击 “ 删 除 ”按钮 时 将 导致 回 传 ,GridView 控件 检测 到 特定 行 
的 “删除 ”按钮 被 单 击 ,并 相应 地 生成 其 RowDeleting 事件 ,然后 GridView 控件 取得 唯一 标识 
该 行 的 值 (如 student 表 的 学 号 ) ,将 它 赋 给 其 数据 源 控件 的 删除 参数 (如 @ 学 号 ) ,并 调用 其 
DeleteCommand, 然 后 数据 源 控件 向 数据 库 ( 如 Stud 数据 库 ) 发 出 DELETE 语句 ,并 替换 其 @ 
学 号 参数 的 值 。 通 过 数据 源 控件 删除 该 记录 后 ,GridView 控件 生成 其 RowDeleted 事件 。 

(2) 编辑 操作 

当 用 户 单 击 “ 编 辑 ” 按 钮 时 ,网 页 被 刷新 , 且 其 “编辑 ”按钮 被 单 击 的 那个 行将 进入 可 编辑 状 
态 , 用 户 可 以 为 可 编辑 字段 输入 新 值 , 单 击 “ 更 新 ” 超 链 接 保存 所 做 的 修改 。 

编辑 操作 的 工作 原理 : 用 户 单 击 “ 编 辑 ” 按 钮 时 将 导致 回 传 ,GridView 控件 检测 到 特定 行 
的 “编辑 ”按钮 被 单 击 , 并 相应 地 生成 其 RowEditing 事件 。 若 用 户 修改 后 单 击 “ 取 消 ” 按 钮 , 则 
相应 地 生成 RowCancelingEdit 事件 。 若 用 户 修改 后 单 击 “ 更 新 ”按钮 , 则 生成 其 RowUpdateing 事 
件 ,然后 GridView 控件 取得 唯一 标识 该 行 的 值 (如 student 表 的 学 号 ) ,将 它 赋 给 其 数据 源 控 
件 的 更 新 参数 (如 @ 学 号 ) ,并 调用 其 UpdateCommand, 然 后 数据 源 控件 向 数据 库 ( 如 Stud 数 
据 库 ) 发 出 UPDATE 语句 ,并 替换 其 @ 学 号 参数 的 值 。 通 过 数据 源 控件 修改 该 记录 后 ， 
GridView 控件 生成 其 RowUpdated 事件 。 

(3) 将 字段 标记 为 只 读 

在 默认 情况 下 ,GridView 控件 中 映射 到 基础 数据 库 表 中 的 主键 列 的 字段 都 是 只 读 的 。 当 
用 户 单 击 GridView 控件 中 某 行 的 “编辑 ”按钮 时 ,只 读 字段 显示 为 文本 ,不 能 更 新 值 。 

用 户 可 选择 将 其 他 字段 标记 为 只 读 ,其 操作 是 选择 “GridView 任务 ”列表 中 的 “编辑 列 ” 命 
令 , 进 入 “字段 "对话 框 ,在 “ 选 定 的 字段 "列表 中 选择 要 标记 为 只 读 的 字段 ,在 “行为 部 分 中 有 
一 个 名 为 ReadOnly 的 属性 ,将 该 属性 设置 为 True 即 可 。 

(4) 编辑 和 格式 化 字段 

GridView 控件 中 每 个 字段 的 DataFormatString 属性 用 于 获取 或 设置 字符 串 ,该 字符 串 
指定 字段 值 的 显示 格式 。 默 认 值 为 空 字符 串 ("") ,表示 尚 无 特殊 格式 设置 应 用 于 该 字段 值 。 
当 GridView 控件 中 字段 的 HtmlEncode 属性 为 True 时 ,会 在 应 用 格式 化 字符 串 之 前 将 字段 
值 通过 HTML 编码 变 成 其 字符 串 表 示 形 式 。 对 于 某 些 对 象 (如 日 期 ), 可 能 需要 通过 格式 化 
字符 串 控制 对 象 的 显示 方式 ,此 时 ,必须 将 HtmlEncode 属性 设置 为 False。 

默认 情况 下 ,只 有 当 包 含 BoundField 对 象 (GridView 控件 中 对 应 表 列 的 每 个 字段 均 为 
BoundField 对 象 ) 的 数据 绑 定 控件 处 于 只 读 模 式 时 ,格式 化 字符 串 才 应 用 到 字段 值 。 若 要 在 
编辑 模式 中 将 格式 化 字符 串 应 用 到 字段 值 , 需 将 ApplyFormatInEditMode 属性 设置 为 True。 

格式 化 字符 串 可 以 为 任意 字符 串 , 并 且 通 常 包 含 字段 值 的 占 位 符 。 例 如 ,在 格式 化 字符 串 
“Item Value: 10)” 中 , 当 BoundField 对 象 中 显示 字符 串 时 ,字段 的 值 会 代替 10} 占 位 符 。 格 式 
化 字符 串 的 剩余 部 分 显示 为 文本 。 

注意 如 果 格 式 化 字符 串 不 包含 占 位 符 , 则 来 自 数据 源 的 字段 值 将 不 包含 在 最 终 显示 文本 
中 。 占 位 符 由 用 冒号 分 隔 的 两 部 分 组 成 并 用 大 括号 括 起 ,格式 为 {A:Bxx)}。 冒 号 前 的 值 (常规 
示例 中 为 A) 指 定 在 从 零 开 始 的 参数 列表 中 的 字段 值 的 索引 。 注 意 此 参数 是 格式 化 语法 的 一 
部 分 ,因为 每 个 单元 格 中 只 有 一 个 字段 值 ,所 以 这 个 值 只 能 设置 为 0。 

该 冒号 以 及 冒号 后 面 的 值 是 可 选 的 ,冒号 后 的 字符 (常规 示例 中 为 B) 指 定 值 的 显示 格式 。 
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表 12.42 列 出 了 一 些 常 用 格式 。 
表 12.42 常用 的 格式 及 其 说 明 


格式 字符 说 明 说 明 
C 以 货币 格式 显示 数值 以 常规 格式 显示 数值 
D 以 十 进 制 格式 显示 数值 以 数字 格式 显示 数值 
E 以 科学 记 数 法 (指数 ?格式 显示 数值 以 十 六 进 制 格式 显示 数值 
F 以 固定 格式 显示 数值 


其 中 格式 字符 不 区 分 大 小 写 , 但 X 除外 , 它 以 指定 的 大 小 写 形式 显示 十 六 进 制 字 符 。 格 
式 字 符 后 的 值 ( 常 规 示例 中 为 xx) 指 定 显示 的 值 的 有 效 位 数 或 小 数位 数 。 例 如 ,格式 化 字符 串 
“(0:F2}” 将 显示 带 两 位 小 数 的 定点 数 。 

4. 列 对 象 处 理 

(1) 列 字段 

在 默认 情况 下 ,GridView 控件 的 AutoGenerateColumns 属性 被 设置 为 True, 为 数据 源 中 
的 每 一 个 列 创建 一 个 字段 。 然 后 每 个 字段 作为 GridView 控件 中 的 列 呈 现 ,其 顺序 与 每 一 字 
段 在 数据 源 中 出 现 的 顺序 相同 。 

通过 将 AutoGenerateColumns 属性 设置 为 False, 然 后 定义 自己 的 列 字段 集合 ,也 可 以 手 
动 控制 哪些 列 字段 将 显示 在 GridView 控件 中 。 不 同 的 列 字 段 类 型 决定 控件 中 各 列 的 行为 。 
表 12. 43 列 出 了 可 以 使 用 的 不 同 列 字段 类 型 。 


表 12.43 GridView 控件 的 列 字段 类 型 及 其 说 明 


列 字段 类 型 说 明 
BoundField 显示 数据 源 中 某 个 字段 的 值 。 这 是 GridView 控件 的 默认 列 类 型 
ButtonField 为 GridView 控件 中 的 每 个 项 显示 一 个 命令 按钮 。 这 样 可 以 创建 一 列 自 定义 按钮 


控件 ,如 * 添 加 ”按钮 或 " 移 除 "按钮 

CheckBoxField 为 GridView 控件 中 的 每 一 项 显示 一 个 复 选 框 。 此 列 字段 类 型 通常 用 于 显示 具有 
布尔 值 的 字段 

CommandField 显示 用 来 执行 选择 、 编 辑 或 删除 操作 的 预定 义 命令 按钮 

HyperLinkField 将 数据 源 中 某 个 字段 的 值 显 示 为 超 链接 。 此 列 字段 类 型 允许 将 另 一 个 字段 绑 定 到 


超 链 接 的 URL 

JImageField 为 GridView 控件 中 的 每 一 项 显示 一 个 图 像 

TemplateField 根据 指定 的 模板 为 GridView 控件 中 的 每 一 项 显示 用 户 定义 的 内 容 。 此 列 字段 类 
型 允许 创建 自 定义 的 列 字 段 


选择 “GridView 任务 ?列表 中 的 “编辑 列 ” 命 令 , 打 开 * 字 段 ? 对 话 框 , 如 图 12. 52 所 示 ,通过 
该 对 话 框 可 以 进行 列 字段 的 添加 .删除 ,或 对 列 字段 的 属性 进行 设置 等 ,如 利用 HeaderText 
属性 设置 列 字段 呈现 的 文本 。 

(2) 使 用 列 模板 

有 时 候 , 用 户 需要 的 功能 是 系统 提供 的 列 字段 类 型 中 不 具备 的 .这样 需 要 为 应 用 程序 添加 
列 模板 。 

添加 列 模板 有 两 种 方式 : 第 一 种 是 通过 “字段 "对话 框 中 的 “可 用 字段 "列表 选取 
TemplateField 选项 , 单 击 “ 添 加 ”按钮 , 则 在 " 选 定 的 字段 ”列表 中 创建 了 一 个 模板 列 。 第 二 种 
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图 12. 52 “字段 "对话 框 


方式 是 通过 把 一 个 “ 选 定 的 字段 ”列表 中 现 有 的 列 转换 为 模板 列 ,通过 单 击 “ 将 此 字段 转换 为 
TemplateField” 超 链接 完成 。 
在 完成 模板 的 转换 后 .选择 "GridView 任务 ”列表 中 的 “编辑 模板 ”命令 ,就 可 以 编辑 该 模 
板 。TemplateField 类 包含 如 表 12. 44 所 示 的 多 个 模板 。 
表 12.44 模板 类 型 


模板 类 型 说 明 
HeaderTemplate 在 列 头 部 显示 一 个 单元 格 
FootTemplate 在 列 尾 部 显示 一 个 单元 格 
ltemTemplate 显示 模式 下 的 每 行 单元 格 
AlternatiingltemTemplate 显示 模式 下 的 隔行 单元 格 
EditltemTemplate 编辑 模式 下 的 单元 格 
EmptyDataTemplate 当 没 有 相应 数据 时 呈现 给 用 户 的 外 观 表 示 
PagerTemplate 分 页 模式 下 呈现 的 外 观 


【 例 12.19】 设计 一 个 通过 GridView 控件 显示 score 表 记 录 的 网 页 WebForm10, 要 求 显 
示 分 数 对 应 的 等 级 。 

解 : 其 步骤 如 下 。 

@O 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForml0 空 网 页 。 

@ 向 其 中 拖 放 一 个 GridView 控件 GridView1, 在 "GridView 任务 "列表 中 选择 “自动 套 
用 格式 ”命令 ,通过 弹出 的 对 话 框 设置 GridViewl 控件 的 外 观 为 "沙滩 和 天 空 ”, 如 图 12. 53 
所 示 。 

@ 选择 “新 建 数据 源 ” 命 令 ,在 出 现 的 “选择 数据 源 类 型 "对 话 框 中 单 击 “ 数 据 库 ,保持 默 
认 的 名 称 为 SqlDataSourcel, 然 后 单 击 “确定 按钮 。 
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图 12.53 “自动 套用 格式 "对 话 框 


@ 出 现 “ 选 择 您 的 数据 连接 "对话 框 ,可 以 从 “应 用 程序 连接 数据 库 应 使 用 哪个 数据 连接 ” 列 
表 中 选择 前 面 在 Web. config 中 添加 的 数据 连接 ,这 里 选择 连接 字符 串 “StudConnectionString” 
(StudConnectionString 连接 字符 串 是 在 例 12. 16 中 创建 的 ) ,如 图 12. 54 所 示 ,再 单 击 “下 一 
步 " 按 钮 ,按照 前 面 建立 SqlDataSource 控件 数据 源 的 方式 指定 数据 源 为 Stud 数据 库 的 


score 表 。 


| < 上 sm | Fesm- |[ sn || 


图 12. 54 “选择 您 的 数据 连接 ”对 话 框 


@ 从 “GridView 任务 ”列表 中 选择 “编辑 列 " 命 令 ,出现 “字段 ”对 话 框 ,从 “可 用 字段 ”列表 
中 选中 “TemplateField”, 单 击 “ 添 加 ”按钮 将 其 加 入 到 “* 选 定 的 字段 ”列表 中 ,然后 选中 它 , 在 
TemplateField 属性 中 将 HeaderText 属性 改 为 “等 级 ”, 如 图 12. 55 所 示 ,再 单 击 “确定 ”按钮 返回 。 
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图 12. 55 “字段 "对 话 框 


@ 在 "GridView 任务 ”列表 中 选择 “编辑 模板 ”命令 ,出 现 如 图 12. 56 所 示 的 “模板 编辑 模 
式 ” 列 表 , 从 中 选择 ItemTemplate。 在 ItemTemplate 区 中 拖 放 一 个 Label 控件 ,从 “Label 任 
务 ” 列 表 中 选择 “编辑 DataBindings” 命 令 ,打开 Labell DataBindings 对 话 框 ,选中 “ 自 定义 绑 
定 ? 单 选 按钮 ,在 “代码 表达 式 ” 文 本 框 中 输入 GetLevel(Eval(" 分 数 ")), 如 图 12. 57 所 示 , 单 击 
“确定 ”按钮 返回 后 选择 “GridView 任务 ”列表 中 的 “结束 编辑 模板 ”命令 ,再 设置 GridView1l 控 
件 的 AllowPaging 属性 为 True、PageSize 属性 为 5。 


asp:gridview#GridViewl| 


Gridyiewl -Column -等 级 


pr pe 
EdititemTemplate 
HeaderTemplate 
模板 编辑 处 : 可 以 从 工 selbst ae MN 

具 箱 抑 放 控件 到 其 中 PagerTemplate 


图 12.56 “模板 编辑 模式 "列表 


注意 : 数据 绑 定 表达 式 包含 在 所 中 和 中 二 分 隔 符 之 内 ,并 使 用 Eval 或 Bind 函数 。Eval 
函数 用 于 定义 单 向 (只 读 ) 绑 定 ,Bind 函数 用 于 定义 双向 (可 更 新 ) 绑 定 。 在 调用 控件 或 Page 
对 象 的 DataBind 方法 时 会 对 数据 绑 定 表达 式 进 行 解析 。 当 控件 仅 显 示 值 时 可 以 使 用 Eval 方 
法 , 当 用 户 可 以 修改 数据 值 时 可 以 使 用 Bind 方法 。 如 果 模 板 包 含 值 可 能 被 用 户 更 改 的 控件 ， 
如 TextBox 或 CheckBox 控件 ,或 者 模板 允许 删除 记录 , 则 需 使 用 Bind 方法 。 
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[GettevellEval 分 数 咱 


图 12. 57 Labell DataBindings 对 话 框 


@ 在 本 网 页 上 设计 如 下 方法 : 
public string GetLevel(object s) 


LI 


} 


int fs = int.Parse(s. ToString()); 
if (fs>=90) 
return(" 优 "); 
else if (fs>=80) 
return(" 良 "); 
else if (fs>=70) 
return(" 中 "); 
else if (fs>=60) 
return(" 及格") 
else 


return(" 不 及 格 "); 


WebForm9 网 页 源 视图 代码 中 的 二 body 二 部 分 如 下 : 
<body> 


<form id= "forml" runat = "server"> 
<div> 
<asp:GridView ID= "GridViewl" runat = "server" AllowPaging = " True" 
RutoGenerateColumns = "False" BackColor = "LightGoldenrodYellow" 
BorderColor = "Tan" BorderWidth= "lpx" CellPadding = "2" 
DataKeyNames = "学 号 ,课程 名 "DataSourceID = "SqlDataSourcel" 
ForeColor = "Black" GridLines = "None" PageSize = "5"> 
<AlternatingRowStyle BackColor = "PaleGoldenrod" /> 
<Columns > 
<asp:BoundField DataField = "学 号 ”HeaderText = "学 号 " ReadOnly = "True" 
SortExpression = "学 号 " /> 
<asp:BoundField DataField= "课程 名 ”HeaderText = "课程 名 " ReadOnly = "True" 
SortExpression = "课程 名 " 人 > 
<asp:BoundField DataField = "分 数 ”HeaderText = "分 数 " 
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SortExpression = "分 数 " /> 
<asp:TemplateField HeaderText = "等 级 "> 
< ItemTemplate> 
<asp:Label ID = "Labell" runat = "server" 
Text = '<S% 井 GetLevel(Eval(" 分 数 ")) %>></asp:Label> 
</ItemTemplate> 
</asp:TemplateField> 
</Columns> 
< FooterStyle BackColor = "Tan" /> 
< HeaderStyle BackColor = "Tan" Font - Bold= "True" /> 
< PagerStyle BackColor = "PaleGoldenrod" ForeColor = "DarkSlateBlue" 
HorizontalAlign = "Center" /> 
< SelectedRowStyle BackColor = "DarkSlateBlue" ForeColor = "GhostWhite" /> 
< SortedAscendingCellStyle BackColor =" # FAFAE7" /> 
< SortedAscendingHeaderStyle BackColor = " #DACO9E" /> 
< SortedDescendingCellStyle BackColor ="#E1DB9C" /> 
< SortedDescendingHeaderStyle BackColor ="#C2A47B" /> 
</asp:GridView> 
<asp:SqlDataSource ID = "SqlDataSourcel" runat = "server" 
ConnectionString = "<% $ ConnectionStrings:StudConnectionString $%>" 
DeleteCommand = "DELETE FROM [ score] WHERE [学 号 ] = @ 学 号 
AND [课程 名 ] = @ 课 程 名 " 
InsertCommand = "INSERT INTO [ score] ([ 学 号 ], [课程 名 ], [分数 ]) 
VALUES (@ 学 号 , @ 课 程 名 ，@ 分 数 )" 
SelectCommand = "SELECT [学 号 ], 【课程 名 ], [分 数 ] FROM [ score]" 
UpdateCommand = "UPDATE [ score] SET [分 数 ] = @ 分 数 
WHERE [学 号 ] = @ 学 号 AND [课程 名 ] = @ 课 程 名 "> 
<DeleteParameters > 
<asp:Parameter Name = "学 号 " Type= "String" /> 
<asp:Parameter Name = "课程 名 " TYpe= "String" /> 
</DeleteParameters> 
< InsertParameters > 
<asp:Parameter Name = "学 号 " TYpe= "String" /> 
<asp:Parameter Name = "课程 名 "Type= "String" /> 
<asp:Parameter Name = "分 数 " TYpe= "Double" /> 
</ InsertParameters> 
<UpdateParameters > 
<asp:Parameter Name = "分 数 " TYpe= "Double" /> 
<asp:Parameter Name = "学 号 " Type= "String" /> 
<asp:Parameter Name = "课程 名 ”Type= "String" /> 
</UpdateParameters > 
</asp:SqlDataSource > 
</div> 
</form> 
</body> 


图 单 击 工具 栏 中 的 Pp IntemetExplorer 按钮 运行 本 网 
页 ,其 结果 如 图 12. 58 所 示 , 从 中 看 到 等 级 列 会 自动 调用 
GrtLevel 方法 产生 相应 的 结果 。 

【 例 12. 20】 设计 一 个 通过 GridView 控件 显示 
student 表 记 录 的 网 页 WebForm11 ,要求 显示 界面 美观 。 

解 : 其 步骤 如 下 。 

中 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 图 12.58 WebForml0 网 页 运行 界面 
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WebFormll 空 网 页 。 
@ 向 其 中 拖 放 一 个 GridView 控件 GridView1。 对 应 网 页 源 视图 代码 的 一 body 之 部 分 
如 下 : 


<body> 
<form id= "forml" runat = "server"> 
<div> 
<asp:GridView ID = "GridViewl" runat = "server" AutoGenerateColumns = "False" 
CellSpacing = "1" DataKeyNames = "学 号 " DataSourceID = "SqlDataSourcel" 
style = "color: #0000FF; font — size:medium;font - weight:400;font - family: 仿 宋 "> 
<Columns > 
<asp:CommandField ButtonType = "Button" ShowSelectButton = "True"> 
< ControlStyle ForeColor =" 井 FEF0066" /> 
</asp:CommandField> 
<asp:BoundField DataField = "学 号 ”HeaderText = "学 号 " ReadOnly = "True" 
SortExpression = "学 号 "> 
< HeaderStyle Font ~ Bold = "True" ForeColor = " 井 FF3399" 
HorizontalAlign = "Center" Width = "60px" /> 
< ItemStyle HorizontalAlign= "Center" /> 
</asp:BoundField> 
<asp:BoundField DataField = "姓名 ”HeaderText = "姓名 " 
SortExpression = "姓名 "> 
< HeaderStyle ForeColor = " #FF3399" HorizontalAlign = "Center" 
Width = "70px" /> 
< ItemStyle HorizontalAlign= "Center" /> 
</asp:BoundField> 
<asp:BoundField DataField = "民族 ”HeaderText = "民族 " 
SortExpression = "民族 "> 
< HeaderStyle ForeColor = " #FF3399" HorizontalAlign = "Center" 
Width = "50px" /> 
< ItemStyle HorizontalAlign= "Center" /> 
</asp:BoundField> 
<asp:BoundField DataField = " 班 号 ” HeaderText =" 班 号 " 
SortExpression = " 班 号 "> 
< HeaderStyle ForeColor = " #FF3399" HorizontalAlign = "Center" 
Width = "60px" /> 
< ItemStyle HorizontalAlign= "Center" /> 
</asp:BoundField> 
<asp:TemplateField HeaderText = "性 别 "> 
<ItemTemplate> 
<asp:RadioButton ID = "RadioButton1l" runat = "server" 
Checked = '<% 井 Getxbl(Eval(" 性 别 ")) 名 >' Text = " 男 " /> 
<asp:RadioButton ID= "RadioButton2" runat = "server" 
Checked = '<% 井 Getxb2(Eval(" 性 别 ")) %>'Text = " 女 " /> 
</ItemTemplate > 
< HeaderStyle ForeColor = " #FF3399" HorizontalAlign = "Center" 
Width = "80px" /> 
</asp:TemplateField> 
</Columns> 
< SelectedRowStyle BackColor = " 划 009933" /> 
</asp:GridView> 
<asp:SqlDataSource ID = "SqlDataSourcel" runat = "server" 
<- 这 部 分 代码 与 例 12.16 中 SqlDataSourcel 的 源 视 图 代码 相同 -> 
</asp:SqlDataSource > 
</div> 
</form> 
</body > 
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@ 在 本 网 页 上 设计 如 下 两 个 方法 : 


public bool Getxbl(object s) 

{ stringxb = s.ToString(); 
if (xb == " 男 ") return true; 
else return false; 

} 

public bool Getxb2(object s) 

' string xb = s.ToString(); 
if (xb == " 女 ") return true; 
else return false; 


} 


@ 单 击 工具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 ,首先 显示 所 有 学 生 记录 ,然后 单 击 6 
号 学 生 记录 前 的 “选择 ?按钮 ,该 选择 行 的 背景 颜色 发 生 改变 ,其 结果 如 图 12. 59 所 示 。 

5. DataBinder 类 = 

在 前 面 的 示例 中 使 用 了 动态 绑 定 ,实际 ”|@Y 国人 @ wwecanonsls5mevrom PP- | 
上 是 使 用 DataBinder 类 实现 的 ,该 类 提供 对 ” 
应 用 程序 快速 开发 设计 器 的 支持 以 生成 和 
分 析 数 据 绑 定 表 达 式 语法 。 在 网 页 数据 绑 
定语 法 中 可 以 使 用 此 类 的 静态 方法 Eval 在 
运行 时 计算 数据 绑 定 表达 式 。 与 标准 数据 
绑 定 相 比 ,其 提供 的 语法 更 容易 记忆 ,但 是 
因为 DataBinder. Eval 提供 自动 类 型 转换 ， 
这 会 导致 服务 器 响应 时 间 变 长 。 图 12.59 WebFormll 网 页 运行 界面 

Eval 方 法 的 基本 语法 格式 如 下 : 


public static Object Eval(Object container, string expression) 


其 中 ,参数 container 指出 进行 计算 的 对 象 引 用 。expression 指出 从 container 到 要 放置 在 
绑 定 控件 属性 中 的 公共 属性 值 的 导航 路 径 。 其 返回 值 为 Object, 它 是 数据 绑 定 表达 式 的 计算 
结果 。 

用 户 必 须 将 二 闪闪 和 儿 过 标记 放 在 数据 绑 定 表达 式 的 两 头 , 这 些 标记 也 用 于 标准 ASP . 
NET 数据 绑 定 。 当 数据 绑 定 到 模板 列表 中 的 控件 时 ,此 方法 尤其 有 用 。 

对 于 所 有 的 列表 Web 控件 ,如 DataGrid .DataList 或 Repeater, container 参数 值 均 应 为 
“Container. DataItem”。 如 果 要 对 页 进行 绑 定 , 则 container 参数 值 应 为 "Page”。 

例如 ,使 用 Eval 方法 绑 定 到 Price 字段 ,其 使 用 代码 如 下 : 


< 外 井 DataBinder.Eval(Container. DatalItem, "Price") %> 


6. GridViewRow 类 

GridView 控件 中 的 单独 行 就 是 一 个 GridViewRow 对 象 。 

GridView 控件 将 其 所 有 数据 行 都 存储 在 Rows 集合 中 。 若 要 确定 Rows 集合 中 
GridViewRow 对 象 的 索引 , 需 使 用 RowIndex 属性 。 

通过 使 用 Cells 属性 可 以 访问 GridViewRow 对 象 的 单独 单元 格 。 如 果 某 个 单元 格 包含 
其 他 控件 , 则 通过 使 用 单元 格 的 Controls 集合 可 以 从 单元 格 检索 控件 。 如 果 控 件 指定 了 ID， 
还 可 以 使 用 单元 格 的 FindControl 方法 来 查找 该 控件 。 
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若 要 从 BoundField 字段 列 或 自动 生成 的 字段 列 检索 字段 值 , 需 使 用 单元 格 的 Text 属性 。 
若 要 从 将 字段 值 绑 定 到 控件 的 其 他 字段 列 类 型 检索 字段 值 , 先 从 相应 的 单元 格 检索 控件 ,然后 
访问 该 控件 的 相应 属性 。 

在 以 下 代码 中 ,使 用 GridViewRow 对 象 从 GridView 控件 中 的 单元 格 检索 字段 值 , 然 后 
在 该 网 页 上 显示 该 值 : 

GridViewRow selectRow = GridViewl.SelectedRow; 

String txt = selectRow.Cells[1].Text; 

【 例 12.21】 设计 一 个 通过 GridView 控件 修改 student 表 记 录 班 号 的 网 页 WebForm12。 

解 : 其 步骤 如 下 。 

g@ 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForml2 空 网 页 。 

@ 向 其 中 拖 放 一 个 GridView 控件 GridView1, 在 其 下 方 拖 放 一 个 Button 控件 Buttonl ， 
并 将 本 网 页 的 StyleSheetTheme 属性 指定 为 Blue。 

@ 在 "GridView 任务 ”列表 中 选择 “自动 套用 格式 ”命令 设置 为 石板”, 然 后 按照 上 例 方 
法 设置 其 连接 字符 串 为 “StudConnectionString”, 并 指定 连接 到 student 表 , 这 样 建 立 了 
SqlDataSourcel 控件 , 单 击 “ 确 定 ” 按 钮 。 

@ 在 “GridView 任务 ”列表 中 选择 “编辑 列 " 命 令 , 打 
开 “ 字 段 ” 对 话 框 ,从 “ 选 定 的 字段 "列表 中 选中 “ 班 号 ”, 单 
击 右 下 方 的 “将 此 字段 转换 为 TemplateField” 超 链接 , 然 
后 单 击 “ 确 定 ”按钮 返回 。 

@ 在 "GridView 任务 "列表 中 选择 “编辑 模板 ”命令 ， 
指定 ItemTemplate 模板 ,删除 原来 的 Label 控件 ,向 其 中 | 保存 更 改 | 
拖 放 一 个 TextBox 控件 TextBoxl, 如 图 12. 60 所 示 。 图 12. 60 定义 ltemTemplate 模板 

@ 从 “TextBox 任务 "列表 中 选择 “编辑 DataBindings” 
命令 ,打开 TextBoxl DataBindings 对 话 框 ,选中 “ 自 定义 绑 定 ” 单 选 按 钮 ,在 “代码 表达 式 ” 文 
本 框 中 输入 “DataBinder. Eval(Container. Dataltem," 班 号 ")”, 如 图 12. 61 所 示 。 单 击 “ 确 定 ” 
按钮 返回 ,然后 选择 “GridView 任务 ”列表 中 的 “结束 编辑 模板 ”命令 。 


选择 要 绑 定 到 的 尾 性 ， 然 后 可 通过 选择 字 和 假 来 绑 定 它 。 也 可 使 用 自 定 义 代码 表达 式 旷 定 它 . 


可 刻 定 尾 性 (P): 为 Te 暑 定 

人 © FE(N): 
3 Be i 九 定 到 人 6): 
Visible 格式 (0): 


12. 61 TextBoxl DataBindings 对 话 框 
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@ 在 本 网 页 中 设计 如 下 事件 过 程 : 


protected void Button1_C]lick(object sender, EventArgs e) 


{ 


} 


string no; 
TextBox txtbh; 
int i; 
for (i = 0; i< GridViewl.Rows.Count; i++) 
{ txtbh = GridViewl.Rows[i].FindControl("TextBox1") as TextBox; 
// 在 该 行 中 找 TextBoxl 控件 
no = GridViewl.Rows[i].Cells[0].Text; // 提 取 该 行 的 学 号 
Update(no, txtbh. Text); // 调 用 自 定义 过 程 进行 更 新 
} 


protected void Update( string no, string nbh) 
// 自 定义 过 程 ,用 UPDATE 语句 修改 班 号 


} 


SqlCommand mycmd = new SqlCommand(); 
SqlConnection myconn = new SqlConnection(); 
string mystr; 
mystr = System. Configuration.ConfigurationManager. 
ConnectionStrings[ "myconnstring" ].ToString( ) ;myconn. ConnectionString = mystr; 
myconn. Open( ); 
string mysql = "UPDATE student SET 班 号 ='"” + nbh + "'WHERE 学 号 = " 
+ no + "ni 
mycmd. CommandText = mysql; 
mycmd. Connection = myconn; 
mycmd. ExecuteNonQuery( ); 
myconn. Close( ); 


在 上 述 代码 中 .GridView1. Rows[ 门 就 是 一 个 GridViewRow 对 象 , 它 表 示 GridViewl 控 
件 索 引 为 i 的 行 对 象 ,可 以 使 用 GridViewRow 类 的 相关 方法 实现 更 复杂 的 操作 。 

@ 单 击 工 具 栏 中 的 p> Internet Explorer 按钮 运行 本 网 页 ,用 户 可 以 直接 修改 各 记录 的 班 号 ,如 
图 12. 62 所 示 ,然后 单 击 "保存 更 改 ” 命 令 按 钮 修改 对 应 student 表 中 记录 的 班 号 。 


本 例 不 像 直 接 使 用 GridView 控件 的 编辑 功能 那 
样 ,一 次 只 能 修改 一 个 记录 ,而 是 一 次 可 以 修改 多 个 记 
录 , 达 到 批量 数据 修改 的 目的 ,在 实际 Web 应 用 程序 


设计 中 十 分 有 用 。 
7. DataView 类 


在 GridView 控件 实现 数据 绑 定 的 第 2 种 方法 中 


经 常用 DataView 对 象 。DataView 类 能 够 创建 


DataTable 中 所 存储 数据 的 不 同 视 图 ,用 于 对 DataSet 


中 的 数据 进行 排序 ,过滤 和 查询 等 操作 。DataView 类 


位 于 Syatem. Data 命名 空间 。 


图 12. 62 WebForm1l2 网 页 运行 界面 和 数据 库 中 的 视图 相似 ,DataView 对 象 不 存储 数 


据 , 而 是 表示 其 对 应 的 DataTable 的 已 连接 视图 。 对 


DataView 的 数据 的 更 改 将 影响 DataTable, 对 DataTable 的 数据 的 更 改 将 影响 与 之 关联 的 所 
有 DataView。 
DataView 类 的 构造 函数 如 下 : 
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DataView() 

DataView(table) 

DataView(table, RowFilter, Sort, RowState) 

其 中 ,table 参数 指出 要 添加 到 DataView 的 DataTable; RowFilter 参数 指出 要 应 用 于 
DataView 的 RowFilter; Sort 参数 指出 要 应 用 于 DataView 的 Sort; RowState 参数 指出 要 应 
用 于 DataView 的 DataViewRowState。 

为 给 定 的 DataTable 创建 一 个 新 的 DataView, 可 以 声明 该 DataView, 把 DataTable 的 一 
个 引用 mydt 传 给 DataView 构造 函数 ,例如 : 


DataView mydv = new DataView(mydt); 
用 过 滤 条 件 属性 可 以 得 到 DataView 中 数据 行 的 一 个 子 集合 ,也 可 以 为 这 些 数据 排序 。 
DataTable 对 象 提供 DefaultView 属性 返回 默认 的 DataView 对 象 。 例 如 : 


DataView mydv = new DataView(); 
mydv = myds. Tables["student"].DefaultView; 


上 述 代 码 从 myds 数据 集中 取得 student 表 的 默认 内 容 ,再 利用 相关 控件 (如 
DataGridView) 显 示 内 容 , 指 定数 据 来 源 为 mydv。 
DataView 类 的 常用 属性 如 表 12. 45 所 示 , 常 用 方法 如 表 12. 46 所 示 。 


表 12.45 DataView 类 的 常用 属性 及 其 说 明 


属 性 说 明 
AllowDelete 设置 或 获取 一 个 值 ,该 值 指示 是 否 允许 删除 
AllowEdit 获取 或 设置 一 个 值 ,该 值 指 示 是 否 允 许 编辑 
Allownew 获取 或 设置 一 个 值 ,该 值 指示 是 否 可 以 使 用 Addnew 方法 添加 新 行 
ApplyDefaultSort 获取 或 设置 一 个 值 ,该 值 指示 是 否 使 用 默认 排序 
Count 在 应 用 RowFilter 和 RowStateFilter 之 后 获取 DataView 中 记录 的 数量 
Item 从 指定 的 表 获 取 一 行 数据 
RowFilter 获取 或 设置 用 于 筛选 在 DataView 中 查看 哪些 行 的 表达 式 
RowStateFilter 获取 或 设置 用 于 DataView 中 的 行 状态 筛选 器 
Sort 获取 或 设置 DataView 的 一 个 或 多 个 排序 列 以 及 排序 顺序 
Table 获取 或 设置 源 DataTable 


表 12. 46 DataView 类 的 常用 方法 及 其 说 明 


洲 “ 装 说 明 

Addnew 将 新 行 添加 到 DataView 中 

Delete 删除 指定 索引 位 置 的 行 

Find 按 指定 的 排序 关键 字 值 在 DataView 中 查找 行 

FindRows 返回 DataRowView 对 象 的 数组 ,这 些 对 象 的 列 与 指定 的 排序 关键 字 值 匹配 
ToTable 根据 现 有 DataView 中 的 行 创建 并 返回 一 个 新 的 DataTable 


【 例 12. 22】 设计 一 个 通过 GridView 控件 查找 和 排序 student 表 中 记录 的 网 页 
WebForml3。 

解 : 其 步骤 如 下 。 

@ 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForml13 空 网 页 。 
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加 其 设计 界面 如 图 12. 63 所 示 , 其 中 有 一 个 5X5 的 表格 ,包含 两 个 文本 框 (TextBoxl 用 


于 输入 学 号 , TextBox2 用 于 输入 姓名 )、3 个 下 拉 列 表 (DropDownListl 用 于 选择 民族 ， 


DropDownList2 用 于 选择 班 号 , DropDownList3 用 于 选择 排序 字段 )、4 个 单 选 按钮 
(RadioButtonl 和 RadioButton2 为 一 组 ,用 于 选择 性 别 ,RadioButton3 和 RadioButton4 为 一 
组 ,用 于 选择 升降 序 ) 和 两 个 命令 按钮 (Buttonl 为 确定 按钮 ,Button2 为 重 置 按钮 ) 。 


RadioButton1 RadioButton2 


= TextBox2 
-一 共 名 下 | 


| 设置 查询 条 件 | 性 出 | 个 弦 个 女 | 氏族 | 一 二 二 一 一 一 DropDownListl 


DropDownList3 & DropDownList2 RadioButton3 RadioButton4 


图 12.63 WebForml3 网 页 设计 界面 


@ 在 WebForm13 网 页 上 设计 如 下 事件 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
{ if (!Page.IsPostBack) 


{ 


string mystr; 

mystr = System.Configuration.ConfigurationManager. 
ConnectionStrings[ "myconnstring" ].ToString(); 

SqlConnection myconn = new SqlConnection(); 

myconn. ConnectionString = mystr; 

myconn. Open(); 

// 以 下 设置 DropDownListl 的 绑 定数 据 

DataSet mydsl = new DataSet(); 

SqlDataAdapter mydal = new SqlDataAdapter("SELECT distinct 民族 " + 
"FROM student", myconn); 

mydal. Fill(myds1l, "student"); 

DropDownList1. DataSource = mydsl.Tables["student"]; 

DropDownList1. DataTextField = "民族 "; 

DropDownList1. DataBind(); 

DropDownList1. Items. Insert(0, "所 有 民族 "); 

// 以 下 设置 DropDownList2 的 绑 定数 据 

DataSet myds2 = new DataSet(); 

SqlDataAdapter myda2 = new SqlDataAdapter("SELECT distinct 班 号 "+ 
"FROM student", myconn); 

myda2. Fill(myds2, "student"); 

DropDownList2. DataSource = myds2.Tables["student"]; 

DropDownList2. DataTextField = " 班 号 

DropDownList2. DataBind() 

DropDownList2. Items. Insert(0, "所 有 班 号 "); 

// 以 下 设置 DropDownList3 的 数据 

DropDownList3. Items. Add(" 学 号 "); DropDownList3. Items. Add(" 姓 名 "); 

DropDownList3. Items. Add( "性别 "); DropDownList3. Items. Add(" 民 族 "); 

DropDownList3. Items. Add(" 班 号 "); 
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myconn. Close( ); 

TextBoxl.Text = ""; TextBox2.Text = ""; 
RadioButton1l. Checked = false; RadioButton2.Checked = false; 
RadioButton3. Checked false; RadioButton4.Checked 


false; 


} 
protected void Button1_Click(object sender, EventArgs e) 
{ string condstr = ""; 
// 以 下 根据 用 户 输入 求 得 条 件 表达 式 condstr 
if (TextBoxl. Text != "") 
condstr = "学 号 Like '" + TextBoxl.Text + "%S'"; 
if (TextBox2. Text != "") 
if (condstr != "") 
condstr = condstr + " AND 姓名 Like '”+ TextBox2.Text + "% 
else 
condstr = "姓名 Like '" + TextBox2.Text + "SS '"; 
if (RadioButton1. Checked == true) 
if (condstr != "") 
condstr = condstr + "RND 性 别 = ' 男 "; 
else 
condstr = "性 别 = ' 男 "; 
else if (RadioButton2.Checked == true) 
if (condstr != "") 
condstr = condstr + "RND 性 别 = ' 女 "; 
else 
condstr = "性 别 = ' 女 "; 
if (condstr != "") 
if (DropDownList1. SelectedValue != "所 有 民族 ") 


condstr = condstr + " RND 民族 = '" + DropDownList1. SelectedValue + "" 


if (condstr == "") 
if (DropDownList1.SelectedValue != "所 有 民族 ") 
condstr = "民族 = '" + DropDownList1. SelectedValue + ""; 
if (condstr != "") 
if (DropDownList2. SelectedValue != "所 有 班 号 ") 


condstr = condstr + ”RND 班 号 = '”+ DropDownList2. SelectedValue + ""; 


if (condstr == "") 
if (DropDownList2. SelectedValue != "所 有 班 号 ") 
condstr = " 班 号 = '" + DropDownList2. SelectedValue + ""; 
string orderstr = ""; 
// 以 下 根据 用 户 输入 求 得 排序 条 件 表 达 式 orderstr 
if (RadioButton3.Checked) 
orderstr = DropDownList3.SelectedValue + " ASC"; 
else 
orderstr = DropDownList3.SelectedValue + " DESC"; 
Server.Transfer("WebForm13 - 1.aspx?" + "condstr=" + 
condstr + "&orderstr= ”+ orderstr); 
} 
Protected void Button2_Click(object sender, EventArgs e) 
{ TextBoxl. Text = ""; TextBox2.Text = ""; 
RadioButtonl. Checked = false; RadioButton2.Checked = false; 
RadioButton3. Checked = false; RadioButton4.Checked false; 


} 


@@ 运行 WebForml3 网 页 用 户 单 击 Buttonl 命令 按钮 时 转向 WebForml3-1 网 页 。 
WebForml3-1 设计 界面 如 图 12. 64 所 示 , 其 中 有 3 个 HTML 标签 .两 个 标签 (Labell 和 
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Label2) 和 一 个 GridView 控件 GridViewl, 将 GridViewl 控件 的 PageSize 属性 设 为 2、 
AllowPaging 属性 设 为 True, 并 选择 自动 套用 格式 为 “沙滩 和 天 空 ”。 


芍 询 条 件 : [Labeli] 
排序 字段 : [Labe12] 


设计 | 日 拆 分 |。 源 | 四 | <divhtml-stylel> 加 


图 12.64 WebForml3-1 网 页 设计 界面 


@@ 在 WebForm13-1 网 页 上 设计 如 下 事件 过 程 : 


public partial class WebForm12_1 : System.Web. UI.Page 
{ DataView mydv = new DataView(); // 类 字段 
protected void Page_Load(object sender, EventArgs e) 
{ string condstr = Request. QueryString["condstr"]; 
string orderstr = Request.QueryString["orderstr"]; 
string mystr = System.Configuration.ConfigurationManager. 
ConnectionStrings["myconnstring"].ToString(); 
SqlConnection myconn = new SqlConnection(); 
myconn. ConnectionString = mystr; 
myconn. Open(); 
DataSet myds = new DataSet(); 
SqlDataAdapter myda = new SqlDataAdapter("SELECT #* FROM student", myconn); 
myda. Fill(myds, "student"); 
mydv = myds.Tables["student"].DefaultView; 


// 获 得 DataView 对 象 mydv 
mydv. RowFilter = condstr; // 过 滤 DataView 中 的 记录 
mydv. Sort = orderstr; // 对 DataView 中 的 记录 排序 


GridView1.DataSource = mydv; 

GridView1.DataBind( ); 

Labell. Text = condstr; 

Label2. Text = orderstr; 
} 
protected void GridViewl_ PageIndexChanging(object sender, GridViewPageEventArgs e) 
{ GridViewl.PageIndex = e.NewPageIndex; 

GridView1.DataSource = mydv; 

GridView1.DataBind( ); 


} 


用 户 在 WebForm13-1 网 页 中 单 击 GridViewl 控件 (其 数据 源 没有 使 用 SqlDataSource 控 
件 ) 的 其 他 页 号 (如 页 号 2) 时 并 不 能 实现 自动 分 页 ,而 是 出 现 错误 ,为 此 设计 了 处 理 分 页 的 
GridView1l_PageIndexChanging 事件 处 理 过 程 ,这 样 用户 才 可 以 进行 分 页 操作 。 如 果 采 用 
SqlDataSource 控件 作为 GridViewl 控件 的 数据 源 , 则 不 需要 这 样 处 理 就 可 以 进行 分 页 操作 。 
由 于 这 些 数据 源 控 件 具 有 一 些 自动 处 理 表格 的 功能 ,因此 省 去 了 许多 手工 编码 工作 。 

@ 单 击 工具 栏 中 的 > Internet Explorer 按钮 运行 WebForml3 网 页 ,从 性 别 中 单 击 “ 男 ”, 在 排 
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序 条 件 设置 下 拉 列 表 中 选中 “降序 "(其 他 内 容 取 默认 值 ), 如 图 12. 65 所 示 , 单 击 “ 确 定 ” 按 钮 ， 
转向 WebForm13-1 网 页 ,其 结果 如 图 12. 66 所 示 ,用户 可 以 单 击 分 页 号 显示 相应 的 页 面 。 


| htp://iocalhost5115 DD- © 
看 localhost x 
查询 条 件 : 性 别 = ' 男 " 
排序 字段: 学 号 DESC 
查询 结果 : 


8 马 模 男 回族 09002 
| 6 张 军 男 汉族 09001 
12 


12.65 WebForm13 网 页 运行 界面 12. 66 WebForm13-1 网 页 运行 界面 


12.6.4 ” ”DetailsView 控件 


DetailsView 控件 显示 来 自 数据 源 的 单条 记录 的 值 ,其 中 每 个 数据 行 表示 该 记录 的 一 个 字 
段 。 它 可 与 GridView 控件 结合 使 用 ,用 于 主 /详细 信息 方案 。DetailsView 控件 支持 的 功能 
有 绑 定 到 数据 源 控件 (如 AccessDataSource) ,内 置 插 和 功能, 内置 更 新 和 删除 功能 ,内 置 分 页 
功能 ,以 编程 方式 访问 DetailsView 对 象 模型 以 动态 设置 属性 ,处 理事 件 等 。 

DetailsView 控件 的 许多 用 法 与 GridView 控件 类 似 。DetailsView 控件 的 常用 属性 及 其 
说 明 如 表 12. 47 所 示 , 常 用 方法 及 其 说 明 如 表 12. 48 所 示 , 常 用 事件 及 其 说 明 如 表 12. 49 
所 示 。 

表 12. 47 ”DetailsView 控件 的 常用 属性 及 其 说 明 


属 性 说 明 

AllowPaging 获取 或 设置 一 个 值 ,该 值 指示 是 否 启用 分 页 功能 

AutoGenerateDeleteButton 获取 或 设置 一 个 值 ,该 值 指示 用 来 删除 当前 记录 的 内 置 控件 是 否 在 DetailsView 
控件 中 显示 

AutoGenerateEditButton ”获取 或 设置 一 个 值 ,该 值 指示 用 来 编辑 当前 记录 的 内 置 控件 是 否 在 DetailsView 
控件 中 显示 

AutoGenerateInsertButton ”获取 或 设置 一 个 值 , 该 值 指示 用 来 插入 新 记录 的 内 置 控件 是 否 在 DetailsView 
控件 中 显示 

AutoGenerateRows 获取 或 设置 一 个 值 ,该 值 指示 对 应 于 数据 源 中 每 个 字段 的 行 字段 是 否 自动 生成 
并 在 DetailsView 控件 中 显示 

Dataltem 获取 绑 定 到 DetailsView 控件 的 数据 项 

DataltemCount 获取 基础 数据 源 中 的 项 数 

DataltemIndex 从 基础 数据 源 中 获取 DetailsView 控件 中 正在 显示 的 项 的 索引 

DataKey 获取 一 个 DataKey 对 象 ,该 对 象 表 示 所 显示 的 记录 的 主键 

DataMember 当 数 据 源 包含 多 个 不 同 的 数据 项 列表 时 获取 或 设置 数据 绑 定 控件 绑 定 到 的 数 
据 列表 的 名 称 

DataSource 获取 或 设置 对 象 .数据 绑 定 控件 从 该 对 象 中 检索 其 数据 项 列表 

DataSourcelD 获取 或 设置 控件 的 ID, 数 据 绑 定 控件 从 该 控件 中 检索 其 数据 项 列表 


DefaultMode 获取 或 设置 DetailsView 控件 的 默认 数据 输入 模式 
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续 表 

属 性 说 明 
GridLines 获取 或 设置 DetailsView 控件 的 网 格 线 样式 
HorizontalAlign 获取 或 设置 DetailsView 控件 在 页 面 上 的 水 平 对 齐 方式 
InsertRowStyle 获取 一 个 对 TableltemStyle 对 象 的 引用 ,该 对 象 允许 用 户 设置 在 DetailsView 控 

件 处 于 插入 模式 时 DetailsView 控件 中 的 数据 行 的 外 观 

PageCount 获取 数据 源 中 的 记录 数 
Pagelndex 获取 或 设置 所 显示 的 记录 的 索引 
SelectedValue 获取 DetailsView 控件 中 的 当前 记录 的 数据 键 值 


表 12. 48 DetailsView 控件 的 常用 方法 及 其 说 明 
方 法 说 明 

ChangeMode 将 DetailsView 控件 切换 为 指定 模式 newMode。newMode 的 取 值 为 DetailsViewMode. 
Edit (DetailsView 控件 处 于 编辑 模式 ,这 样 用 户 就 可 以 更 新 记录 的 值 )、 
DetailsViewMode. Insert(DetailsView 控件 处 于 插入 模式 ,这 样 用 户 就 可 以 向 数据 源 中 
添加 新 记录 ) 或 DetailsView. ReadOnly(DetailsView 控件 处 于 只 读 模 式 ,这 是 通常 的 显 
示 模 式 ) 

DataBind 将 来 自 数据 源 的 数据 绑 定 到 控件 

Deleteltem 从 数据 源 中 删除 当前 记录 

Insertltem 将 当前 记录 插入 到 数据 源 中 

Updateltem 更 新 数据 源 中 的 当前 记录 


表 12. 49 ”DetailsView 控件 的 常用 事件 及 其 说 明 


事 件 说 明 
ItemCommand 当 单 击 DetailsView 控件 中 的 按钮 时 发 生 
ItemCreated 在 DetailsView 控件 中 创建 记录 时 发 生 
ltemDeleted 在 单 击 DetailsView 控件 中 的 “删除 ?按钮 时 ,但 在 删除 操作 之 后 发 生 
ltemDeleting 在 单 击 DetailsView 控件 中 的 “删除 ”按钮 时 ,但 在 删除 操作 之 前 发 生 
ltemlnserted 在 单 击 DetailsView 控件 中 的 “插入 ”按钮 时 ,但 在 插入 操作 之 后 发 生 
JtemJnserting 在 单 击 DetailsView 控件 中 的 “插入 ”按钮 时 ,但 在 插入 操作 之 前 发 生 
ItemUpdated 在 单 击 DetailsView 控件 中 的 “更 新 "按钮 时 ,但 在 更 新 操作 之 后 发 生 
ItemUpdating 在 单 击 DetailsView 控件 中 的 “更 新 "按钮 时 ,但 在 更 新 操作 之 前 发 生 
PageIndexChanged 当 Pagelndex 属性 的 值 在 分 页 操作 后 更 改 时 发 生 
PagelndexChanging 当 PagelIndex 属性 的 值 在 分 页 操作 前 更 改 时 发 生 


【 例 12.23】 设计 一 个 通过 DetailsView 控件 操作 student 表 记 录 的 网 页 WebForml4。 

解 : 其 步骤 如 下 。 

Q@ 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForml4 空 网 页 。 

@ 向 其 中 拖 放 一 个 DetailsView 控件 DetailsView1。 在 “DetailsView 任务 ”列表 中 选择 
“新 建 数据 源 ” 命 令 , 如 图 12. 67 所 示 。 

@ 采用 例 12. 20 的 方式 建立 DetailsView1 控件 的 数据 源 控件 为 SqlDataSourcel, 它 用 于 
连接 Stud 数据 库 的 student 表 , 然 后 单 击 “完成 ”按钮 。 

@ 出 现 新 的 “GridView 任务 ”列表 ,如 图 12. 68 所 示 , 勾 选 所 有 启动 选项 ,选择 自动 套用 
格式 为 “沙滩 和 天 空 ”。 


图 12. 67 “GridView 任务 "列表 


第 12 章 ADO.NET 数据 库 访 问 技 


SqlDataSourcel 


| 


图 12.68 新 的 "GridView 任务 ?列表 


该 网 页 的 源 视图 代码 中 的 二 body 二 部 分 如 下 : 


<form id= "forml" runat = "server"> 
<div> 
<asp:DetailsView ID= "DetailsViewl" runat = "server" AllowPaging= "True" 


RutoGenerateRows = "False" BackColor = "LightGoldenrodYellow" 
BorderColor = "Tan" BorderWidth = "lpx" CellPadding = "2" DataKeyNames = 
DataSourceID = "SqlDataSourcel" ForeColor = "Black" GridLines = "None" 
Height = "50px" Width = "210px"> 
<AlternatingRowStyle BackColor = "PaleGoldenrod" /> 
< EditRowStyle BackColor = "DarkSlateBlue" ForeColor = "GhostWhite" /> 
<Fields> 
<asp:BoundField DataField = "学 号 ”HeaderText = "学 号 " ReadOnly = "True" 
SortExpression = "学 号 " /> 
<asp:BoundField DataField = "姓名 ”HeaderText = "姓名 " 
SortExpression = "姓名 " /> 
<asp:BoundField DataField = "性 别 ”HeaderText = "性 别 " 
SortExpression = "性 别 " /> 
<asp:BoundField DataField = "民族 ”HeaderText = "民族 " 
SortExpression = "民族 " /> 
<asp:BoundField DataField = " 班 号 " HeaderText = " 班 号 " 
SortExpression = " 班 号 " /> 
<asp:CommandField ShowDeleteButton = "True" ShowEditButton = "True" 
ShowInsertButton = "True" /> 
</Fields > 
< FooterStyle BackColor = "Tan" /> 
< HeaderStyle BackColor = "Tan" Font ~ Bold = "True" /> 
< PagerStyle BackColor = "PaleGoldenrod" ForeColor = "DarkSlateBlue" 
HorizontalAlign = "Center" /> 
</asp:DetailsView> 
<asp:SqlDataSource ID = "SqlDataSourcel" runat = "server" 
<- 这 部 分 代码 与 例 12.16 中 SqlDataSourcel 的 源 视 图 代码 相同 -> 
</asp:SqlDataSource > 


</div> 
</form> 
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@ 单 击 工 具 栏 中 的 p> Intemet Explorer 按钮 运行 本 网 页 ,其 结果 如 图 12. 69 所 示 。 单 击 “ 新 
建 ” 超 链接 ,出 现 如 图 12. 70 所 示 的 编辑 界面 ,用 户 可 以 输入 相应 的 学 生 记录 。 这 里 单 击 “ 取 
消 ? 超 链接 ,表示 不 新 增 学 生 记录 。 


€ © 您 rtpy/localhost5115 pr- 
感 localhost x 


图 12.69 WebForml4 网 页 运行 界面 一 图 12.70 ”WebForm14 网 页 运行 界面 二 


【 例 12.24】 设计 一 个 通过 GridView 控件 和 DetailsView 控件 操作 student 表 记 录 的 网 
页 WebForml5 。 

解 : 其 步骤 如 下 。 

@ 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 
WebForml5 空 网 页 。 

Q@ 向 其 中 拖 放 一 个 GridView 控件 
GridView1, 指 定 其 自动 套用 格式 为 “沙滩 和 天 
空 "。 然 后 采用 上 例 的 方法 建立 其 数据 源 控件 为 
SqlDataSourcel 控件 , 它 用 于 连接 Stud 数据 库 的 
student 表 , 单 击 “ 完 成 ”按钮 。 

@ 通过 “GridView 任务 "列表 勾 选 “启动 分 
页 "和 “启动 选 定 内 容 ”, 设 置 其 PageSize 属性 
为 3。 

@ 向 网 页 中 GridViewl 控件 的 下 方 拖 放 一 
个 _ DetailsView 控件 _ DetailsViewl, 指定 其 
DataSourceID 为 AccessDataSourcel , 然后 通过 
“DetailsView 任务 "列表 勾 选 “启动 插入 ”和 “启动 
编辑 ” ,指定 自动 套用 格式 为 “红糖 ”。 

@ 再 添加 两 个 起 提示 作用 的 HTML 标签 ， 图 12.71 WebForml5 网 页 设计 界面 
网 页 设计 界面 如 图 12.71 所 示 。 

@ 在 该 网 页 上 设计 如 下 事件 过 程 : 

protected void GridViewl_SelectedIndexChanged( object sender, EventArgs e) 

{ DetailsViewl.ChangeMode(DetailsViewMode. ReadOnly); 


DetailsViewl. PageIndex = GridView1.PageIndex * GridView1.PageSize 
+ GridViewl.SelectedIndex; 


5 设计 |@ 拆 分 |。 源 | [deformsformi> <divv 上 


} 
protected void GridViewl_ PageIndexChanged(object sender, EventArgs e) 
和 DetailsView1.ChangeMode(DetailsViewMode. ReadOnly); 
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DetailsView1. PageIndex = GridView1.PageIndex * GridView].PageSize; 

} 

由 于 GridViewl 控件 具有 选择 和 分 页 功能 ,在 上 面 的 方法 中 使 用 GridVeiwl 控件 的 
PageIndex 和 PageSize 来 决定 DetailsViewl 控件 的 当前 的 页 面 索引 ,使 这 两 个 控件 同步 。 

@ 单 击 工具 栏 中 的 P Internet Explorer 按钮 运行 本 网 页 ,在 GridViewl 控件 中 单 击 页 号 2 并 
选择 学 号 为 6 的 学 生 记录 ,看 到 在 DetailsViewl 控件 中 显示 相应 的 记录 ,如 图 12. 72 所 示 ,此 
时 用 户 可 以 单 击 “ 编 辑 ” 超 链接 修改 该 记录 ,也 可 以 单 击 “ 新 建 ” 超 链接 插入 一 个 新 的 记录 ,如 
图 12.73 所 示 。 


ET 
httpy/localhost5l15 P © 
碟 htpy/localhost5l15P - | 他 妆 读 四 Le 
@ localhost x 
学 生 记 录 操 作 
法!; 汉族 ”09001 
选择 8 ” 马 模 男 
选择 8  ” 马 棋 男 回族 09002 12 
12 单个 学 生 记录 编辑 
单个 学 生 记 录 编 辑 
学 号 6 
姓名 了 张 军 
性 别 男 
民族 汉族 
班 号 09001 
编辑 新 建 
图 12.72 WebForm15 网 页 运行 界面 一 图 12.73 WebForm15 网 页 运行 界面 二 


12.6.5 FormView 控件 


FormView 控件 与 DetailsView 控件 在 功能 上 有 很 多 相似 之 处 ,也 是 用 来 显示 数据 源 中 的 
一 条 记录 ,分 页 显示 下 一 条 记录 ,支持 数据 的 添加 、 删 除 .修改 、 分 页 等 功能 。 

FormView 控件 与 DetailsView 控件 的 不 同 之 处 在 于 DetailsView 控件 使 用 表格 布局 ,在 
此 布局 中 记录 的 每 个 字段 各 自 显示 一 行 ,而 FormView 控件 不 指定 用 于 显示 距离 的 预定 义 布 
局 ,用 户 必须 使 用 模板 指定 用 于 显示 的 布局 。 

读者 可 以 参考 DetailsView 控件 的 用 法 来 学 习 FormView 控件 ,这 里 不 再 详 述 。 


12.6.6 ”DataLisi 控件 


DataList 控件 在 默认 情况 下 以 表格 形式 显示 数据 。 其 优点 是 用 户 可 以 通过 模板 定义 为 数 
据 创 建 任意 格式 的 布局 ,不 仅 可 以 横 排 数据 ,也 可 以 竖 排 数据 ,还 支持 选择 和 编辑 等 。 

DataList 控件 支持 的 模板 如 表 12. 50 所 示 , 在 使 用 时 至 少 需要 定义 ItemTemplate 以 显示 
DataList 控件 中 的 项 (通过 “DataList 任务 "列表 建立 其 数据 源 绑 定 控件 时 自动 定义 
ItemTemplate 模板 ) 。 

DataList 控件 的 常用 属性 及 其 说 明 如 表 12. 51 所 示 , 其 常用 的 方法 为 DataBind, 其 常用 的 
事件 如 表 12. 52 所 示 。 
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模板 名 称 


表 12. 50 DataList 控件 支持 的 模板 
说 明 


Alternatingltem Template 


EditltemTemplate 


FooterTemplate 


HeaderTemplate 


ltemTemplate 


Selectedltem Template 


SeparatorTemplate 


如 果 已 定义 , 则 为 DataList 中 的 交替 项 提供 内 容 和 布局 ; 如 果 未 定义 , 则 使 
用 ItemTemplate 

如 果 已 定义 , 则 为 DataList 中 当前 编辑 的 项 提供 内 容 和 布局 ; 如 果 未 定义 , 则 
使 用 ItemTemplate 

如 果 已 定义 , 则 为 DataList 的 脚注 部 分 提供 内 容 和 布局 ; 如 果 未 定义 ,将 不 显 
示 脚 注 部 分 

如 果 已 定义 , 则 为 DataList 的 页 眉 节 提供 内 容 和 布局 ; 如 果 未 定义 ,将 不 显示 
页 眉 节 

为 DataList 中 的 项 提供 内 容 和 布局 所 要 求 的 模板 

如 果 已 定义 , 则 为 DataList 中 的 当前 选 定 项 提供 内 容 和 布局 ; 如 果 未 定义 , 则 
使 用 ItemTemplate 

如 果 已 定义 , 则 为 DataList 中 各 项 之 间 的 分 隔 符 提供 内 容 和 布局 如果 未 定 
义 , 将 不 显示 分 隔 符 


表 12.51 DataList 控件 的 常用 属性 及 其 说 明 

属 性 说 明 
AlternatingltemTemplate ”获取 或 设置 DataList 中 交替 项 的 模板 
DataKeyField 获取 或 设置 由 DataSource 属性 指定 的 数据 源 中 的 键 字段 
DataKeys 获取 DataKeyCollection 对 象 , 它 存储 数据 列表 控件 中 每 个 记录 的 键 值 
DataMember 获取 或 设置 多 成 员 数 据 源 中 要 绑 定 到 数据 列表 控件 的 特定 数据 成 员 
DataSource 获取 或 设置 源 , 该 源 包含 用 于 填充 控件 中 的 项 的 值 列 表 
DataSourceID 获取 或 设置 数据 源 控件 的 ID 属性 ,数据 列表 控件 应 使 用 它 来 检索 其 数据 源 
Editltemlndex 获取 或 设置 DataList 控件 中 要 编辑 的 选 定 项 的 索引 号 
EditltemStyle 获取 DataList 控件 中 为 进行 编辑 而 选 定 的 项 的 样式 属性 


Editltem Template 
FooterTemplate 


GridLines 


HeaderTemplate 
ltemTemplate 
RepeatColumns 
RepeatDirection 
Selectedlndex 
Selectedltem 
SelectedValue 


SeparatorTemplate 


获取 或 设置 DataList 控件 中 为 进行 编辑 而 选 定 的 项 的 模板 
获取 或 设置 DataList 控件 的 脚注 部 分 的 模板 

当 RepeatLayout 属性 被 设置 为 RepeatLayout. Table 时 ,获取 或 设置 DataList 
控件 的 网 格 线 样式 

获取 或 设置 DataList 控件 的 标题 部 分 的 模板 

获取 或 设置 DataList 控件 中 项 的 模板 

获取 或 设置 要 在 DataList 控件 中 显示 的 列 数 

获取 或 设置 DataList 控件 是 垂直 显示 还 是 水 平 显 示 

获取 或 设置 DataList 控件 中 的 选 定 项 的 索引 

获取 DataList 控件 中 的 选 定 项 

获取 所 选择 的 数据 列表 项 的 键 字段 的 值 

获取 或 设置 DataList 控件 中 各 项 间 分 隔 符 的 模板 


表 12. 52 DataList 控件 的 常用 事件 及 其 说 明 


事 件 说 明 
DataBinding 当 服务 器 控件 绑 定 到 数据 源 时 发 生 
DeleteCommand 对 DataList 控件 中 的 某 个 项 单 击 * 删 除 ? 按 钮 时 发 生 
EditCommand 对 DataList 控件 中 的 某 个 项 单 击 “ 编 辑 ” 按 钮 时 发 生 
ltemCommand 当 单 击 DataList 控件 中 的 任 一 按钮 时 发 生 
ItemCreated 当 在 DataList 控件 中 创建 项 时 在 服务 器 上 发 生 
ItemDataBound 当 项 被 数据 绑 定 到 DataList 控件 时 发 生 


SelectedIndexChanged 


UpdateCommand 


在 两 次 服务 器 发 送 之 间 ,在 数据 列表 控件 中 选择 了 不 同 的 项 时 发 生 
对 DataList 控件 中 的 某 项 单 击 Update 按钮 时 发 生 
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【 例 12.25】 设计 一 个 通过 DataList 控件 显示 student 表 记 录 的 网 页 WebForml6 。 

解 : 其 步骤 如 下 。 

@ 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm16 空 网 页 。 

@ 向 其 中 拖 放 一 个 DataList 控件 DataListl 。 通 过 *DataList 任务 ”列表 选择 “新 建 数 据 
源 ” 命 令 , 采 用 上 例 的 方法 建立 其 数据 源 控件 为 SqlDataSourcel 控件 , 它 用 于 连接 Stud 数据 
库 的 student 表 , 单 击 “ 完 成 ”按钮 。 此 时 运行 该 网 页 ,其 显示 结果 如 图 12. 74 所 示 。 


@ 选择 “DataList 任务 ”列表 中 的 “编辑 模板 ”命令 ,可 以 看 到 ItemTemplate 模板 如 图 12. 75 
所 示 。 


: [学 号 Label 
: 隘 人 2 


图 12.74 WebForm16 网 页 运行 界面 图 12.75 修改 前 的 ltemTemplate 模板 


@ 修改 该 ItemTemplate 模板 如 图 12. 76 所 示 ,删除 标题 文字 ,将 5 个 标签 水 平 排列 。 看 
一 下 “学 号 Label” 标 签 的 绑 定 情况 ,从 其 "Label 任务 ”列表 中 选择 “编辑 DataBindings” 命 令 会 
出 现 “ 学 号 Label DataBindings” 对 话 框 ,如 图 12.77 所 示 ,保持 不 变 。 如 果 是 在 ItemTemplate 
模板 中 新 建 控件 ,其 设置 绑 定 的 方法 与 它 类 似 。 


[学 寻 Label] [姓名 Label] [性别 Label] [民族 Label]  [ 班 呈 Label] 


SalDatasouree -SqlDatasoureel 


图 12.76 定义 ItemTemplate 模板 


学 SLabel DataBindings EE (lc 
迁 择 要 闭 定 到 的 尾 性 ， 然 后 可 通过 选择 字段 来 九 定 它 。 也 可 使 用 乌 定 义 代码 事 达 式 将 定 亡 - 
可 埋 定 尾 性 (P): 为 Tedt 铸 定 
齐 Enabled 例 放 段 半 定 (月 : 
| 9 Visible 纤 定 到 (B): Ead 本 
栓 R(O) 丽 上 上 加 
示人 MMS 
回 显示 所 有 尾 性 (A) 司 自 定义 睹 定 ( 〇 : 
代码 表达 式 (E): 
Eval[ 手 号 7) 
aa 喜 


图 12.77 指定 字段 绑 定 
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Q@ 定义 HeaderTemplate 模板 如 图 12. 78 所 示 ( 输 入 相应 文字 并 设置 字体 和 颜色 ) 。 


HeaderTemplate 
学 号 姓名 性 别 民族 班 号 


SqlDatasource - SqlDataSourcel 
图 12.78 定义 HeaderTemplate 模板 


@ 指定 DataListl 控件 的 自动 套用 格式 为 “沙滩 和 天 空 ”最 终 的 设计 界面 如 图 12. 79 
所 示 。 


on 


5 设计 |m 折 分 |。 源 | [4| <asp:DataListsDatalistl> [| 


图 12.79 WebForml6 网 页 设计 界面 


WebForm16 网 页 源 视图 代码 的 一 body 二 部 分 如 下 : 


<body > 
<form id= "forml" runat = " Server"> 
<div style = "width: 438px"> 
<asp:DataList ID = "DataList1" runat = "server" DataKeyField= "学 号 " 
DataSourceID = "SqlDataSourcel" Height = "61px" Width = "290px" 
BackColor = "LightGoldenrodYellow" BorderColor = "Tan" 
BorderWidth = "lpx" CellPadding = "2" ForeColor = "Black"> 
<RlternatingItemStyle BackColor = "PaleGoldenrod" /> 
< FooterStyle BackColor = "Tan" /> 
< HeaderStyle BackColor = "Tan" Font ~ Bold= "True" /> 
< HeaderTemplate> 
<span class = "auto - stylel"> 学 号 &nbsp&nbsp; 姓名 &nbsp; &nbsp; 
性 别 snbsp;Snbsp; 民族 snbsp;&nbsp; 班 号 </span> 
</HeaderTemplate> 
< ItemTemplate > 
<asp:Label ID = "学 号 Label" runat = "server" CssClass = "auto - style2" 
Text = '<%# Eval(" 学 号 ") %>'/> 
Snbsp; gnbsp; gnbsp; &nbsp; Enbsp; gnbsp; 
<asp:Label ID= "姓名 Label" runat = "server" CssClass = "auto - style2" 
Text = '< 委 井 Eval(" 姓 名 ") %>'/> 
Snbsp; gnbsp; &nbsp; gnbsp; 


第 12 章 ADO.NET 数据 库 访 问 技 


<asp:Label ID = "性 别 Label" runat = "server" CssClass = "auto - style2" 
Text = '<% # Eval(" 性别 ") %>'/> 
Snbsp; gnbsp; gnbsp; gnbsp; 
<asp:Label ID = "民族 Label" runat = "server" CssClass = "auto- style2" 
Text = '<% # Eval(" 民 族 ") %>'/> 
Snbsp; 
<asp:Label ID = " 班 号 Label" runat = "server" CssClass = "auto - style2" 
Text = '< 当 井 Eval(" 班 号 ") %>'/> 
<br /> 
</ ItemTemplate > 
< SelectedItemStyle BackColor = "DarkSlateBlue"” ForeColor = "GhostWhite"” /> 
</asp:DataList> 
<asp:SqlDataSource ID = "SqlDataSourcel" runat = "server" 
<- 这 部 分 代码 与 例 12.16 中 SqlDataSourcel 的 源 视图 代码 相同 -> 
</asp: SqlDataSource > 
</div> 
</form> 


</body > 
@ 单 击 工具 栏 中 的 上 Internet Explorer 按钮 运行 本 网 页 ,运行 界面 如 图 12. 80 所 示 , 其 中 显示 
了 所 有 的 学 生 记录 。 = 一 一 一 一 


【 例 12.26】 设计 一 个 通过 DataList 控件 在 运行 
时 计算 数据 绑 定 表 达 式 的 网 页 WebForm17。 localhost “ 国 


解 : 其 步骤 如 下 。 

@O 在 chl2 网 站 添加 一 个 代码 隐藏 页 模型 的 
WebForml7 空 网 页 。 

@ 向 其 中 拖 放 一 个 DataList 控件 DataListl , 然 
后 在 DataListl 控件 下 方 拖 放 一 个 标签 控件 Labell 。 

G 不 设置 DataListl 控件 的 数据 源 。 设 计 本 网 页 
的 事件 过 程 如 下 : 


protected void Page_Load( object sender, EventArgs e) 
{ stringmystr = System. Configuration.ConfigurationManager. 
ConnectionStrings[ "myconnstring"]. ToString( ); 
SqlConnection myconn = new SqlConnection(); 
myconn. ConnectionString = mystr; 
myconn. Open( ) 
DataSet myds = new DataSet(); 
SqlDataAdapter myda = new SqlDataAdapter("SELECT x FROM ”+ "student", myconn); 
myda. Fill(myds, "student"); 
DataList1. DataSource = myds.Tables["student"]; 
DataList1. DataKeyField = "学 号 "; 
DataList1. DataBind(); 
myconn. Close( ); 


图 12.80 WebForm16 网 页 运行 界面 


下 

上 述 代 码 设 置 DataListl 控件 的 数据 源 并 绑 定 。 

@ 选择 “DataList 任务 ”列表 中 的 “编辑 模板 ”命令 ,定义 ItemTemplate 模板 如 图 12. 81 
所 示 , 其 中 共 5 个 部 分 ,第 1 部 分 输入 “学 号 [ ]”, 第 2~5 部 分 拖 放 LinkButton 控件 
LinkButton1 一 LinkButton4。 为 LinkButtonl 指定 可 绑 定 属性 Text 为 自 定义 绑 定 ,代码 表达 
式 为 “DataBinder. Eval(Container. DataItem," 姓 名 ")”, 如 图 12. 82 所 示 。 
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Datalistl - 项 模板 


| [HemTemplate 


学 号 [] [LinkButtonl] [LinkButton2] [LinkButton3] 


inkButton4 


图 12.81 定义 ItemTemplate 模板 


为 Text 万 定 
字 息 绑 定 (P): 
部 定 到 (B); 


栓 K(O): 


加 自 定义 娜 定 (O: 


12. 82 指定 字段 绑 定 


再 依次 为 LinkButton2 一 LinkButton4 指定 自 定义 绑 定 代 码 表 达 式 为 "DataBinder. Eval 
(Container. Dataltem," 性 别 ")”“DataBinder。Eval (Container。Dataltem," 民族 ")” 和 
“DataBinder. Eval( Container. Dataltem," 班 号 ")”。 

@ 进入 源 视图 代码 ,在 “[” 和 “J]” 之 间 插 入 一 个 绑 定 的 代码 表达 式 , 修 改 代 码 如 下 ( 仅 修改 


粗 体 部 分 ): 


学 号 [<% 井 DataBinder. Eval(Container.DataItem, "学 号 ") %>] 


@ 在 网 页 上 添加 如 下 事件 过 程 : 


protected void DataList1_ItemCommand(object source, DataListCommandEventArgs e) 
{ stringno = DataList1. DataKeys[e. Item. ItemIndex]. ToString(); 
Labell. Text = "你 选择 的 学 生 学 号 为 :"” + no; 


} 


@ 指定 DataListl 控件 的 自动 套用 格式 为 “沙滩 和 天 空 ”, 最 终 的 设计 界面 如 图 12. 83 所 示 。 


[Label1] 


设计 | 日 拆 分 |j。 源 | [J[ehem> 


<formzforml> 


图 12.83 WebForml7 网 页 设计 界面 
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@ 单 击 工具 栏 中 的 P Imternet Explorer 按钮 运行 本 网 页 ,然后 单 击 “ 李 兵 ” 超 链接 ,在 Labell 
控件 中 显示 对 应 的 学 号 为 3, 如 图 12. 84 所 示 。 


®) 鱼 es BE 
Elocalhost x 


EE 玄 汉族 09001 
学 号 


ret 时 09002 
你 选择 的 学 生 学 号 为 :3 


图 12.84 WebForml7 网 页 运行 界面 


注意 : 更 新 .插入 和 删除 数据 的 数据 绑 定 控 件 ( 如 GridView、FormView 和 DetailsView 
控件 ) 会 在 执行 数据 更 新 操作 之 前 自动 验证 是 否 通过 验证 检查 。 


练习 题 12 


. 简 述 数据 库 中 有 哪些 基本 对 象 。 

. 简 述 ADO.NET 模型 的 体系 结构 。 

. 简 述 ADO.NET 数据 库 的 访问 流程 。 

. 简 述 ADO.NET 的 基本 数据 访问 对 象 。 

. 采用 ADO.NET 访问 SQL Server 数据 库 时 通常 使 用 哪个 数据 提供 程序 ? 
. 简 述 DataSet 对 象 的 特点 。 

. 简 述 常用 的 数据 源 控件 及 其 特点 。 

. 简 述 SqlDataSource 数据 源 控件 的 使 用 方法 。 

. 简 述 为 什么 要 进行 数据 绑 定 , 有 哪些 常用 的 数据 绑 定 控件 ? 
. 简 述 列表 控件 绑 定时 需要 设置 哪些 属性 ? 

. 简 述 GridView 控件 的 使 用 方法 。 

.如 何 自 定义 GridView 控件 的 模板 。 

. 简 述 DetailsView 控件 的 使 用 方法 。 

. 简 述 DataList 控件 的 使 用 方法 。 

。. GridView 控件 和 DetailsView 控件 各 适合 什么 场合 ? 


上 机 实验 题 12 


在 chl2 网 页 中 添加 一 个 名 称 为 Experment12 的 网 页 ,放置 一 个 GridView 控件 (套用 格 
式 为 简明 型 ) 用 于 分 页 显示 学 生 的 学 号 、 姓 名 、 Ws 分 数 和 班 号 信息 ,每 页 4 个 记录 ,并 显示 
当前 页 号 和 总 页 数 ,用 户 可 以 通过 “首页 ”“ 上 一 页 ”“ 下 一 页 ”和 “ 尾 页 ”实现 翻 页 操作 ,还 可 以 
在 选择 指定 的 页 号 后 单 击 相 关 命 令 按 钮 直接 转向 指定 的 页 。 图 12. 85 所 示 的 是 显示 的 第 1 


忆 oo 中 四 上 性 


一 
Ww 一 OO 
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页 , 单 击 “ 下 一 页 ”链接 显示 第 2 页 ,如 图 12. 86 所 示 。 


| 伟 napynocalhostsl155/Epermentl2aspx ”PC 


大 localhost < 


当前 页 : ] 总 页 教 : 3 转向 


图 12.85 上 机 实验 题 12 网 页 的 运行 界面 一 


I 太守 


首页 下 一 页 
当前 页 : 2 总 页 数 : 3 转向 


" 国 


图 12.86 上 机 实验 题 12 网 页 的 运行 界面 二 


语言 集成 查询 一 一 LINQ ls 


LINQ(Language-Integrated Query ,语言 集成 查询 ) 是 从 .NET Framework 
3.5 开始 引入 的 一 组 功能 。LINQ 提供 了 标准 的 .易于 学 习 的 查询 和 更 新 数据 
模式 ,大 大 提高 了 程序 的 数据 处 理 能 力 和 开发 效率 。 本 章 介 绍 LINQ 技术 的 基 
本 使 用 方法 。 

本 章 学 习 要 点 : 

回 掌握 LINGQ 的 基本 概念 和 特点 。 

回 掌握 LINQ to Objects 中 各 种 子 句 的 使 用 方法 。 

回 掌 握 LINQ to XML 的 基本 使 用 方法 。 

回 掌握 LINQ to DataSet 的 基本 使 用 方法 。 

回 掌 握 O/R 映射 器 和 LINQ to SQL 的 基本 使 用 方法 。 

回 掌握 ADO.NET 实体 框架 和 LINQ to Entities 的 使 用 方法 。 

回 灵 活 地 使 用 LINQ 实现 各 种 较 复 杂 的 数据 查询 。 


13.1 LINQ 概述 


13.1.1 什么 是 LINO 


LINQ 使 程序 员 可 以 使 用 类 似 SQL 的 语言 操作 多 种 数据 源 。 例 如 ,可 以 使 
用 C# 查询 Access 数据 库 .ADO . NET 数据 集 、XML 文档 以 及 任何 实现 
IEnumerable 接口 或 IEnumerable 一 T 二 泛 型 接口 的 .NET Framework 集合 类 。 
LINQ 定义 了 一 组 可 以 在 .NET Framework 3.5 及 以 上 版 本 中 使 用 的 通用 
标准 查询 运算 符 , 使 用 这 些 标准 查询 运算 符 可 以 投影 .筛选 和 遍历 内 存 中 的 上 
述 数据 集中 的 数据 。 对 LINGQ 的 几 个 优点 说 明 如 下 。 
。 集成 性 : 把 查询 语法 集成 到 C# 语 言 中 ,成 为 C 革 的 一 种 语法 ; 把 以 前 
复杂 查询 前 的 工作 都 集成 封装 起 来 ,让 开发 人 员 侧重 于 查询 。 
。 统一 性 : 对 于 支持 的 数据 源 使 用 统一 的 查询 语法 ,使 代码 维护 变 得 更 加 
简单 。 
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。 可 扩展 性 : LINQ 提供 了 LINQ provider model, 可 以 为 LINQ 创建 或 提供 provider 让 
LINQ 支持 更 多 的 数据 源 , 如 LINQ to JavaScript 和 LINQ to MySQL 等 。 

。 说 明 式 编程 : 开发 人 员 只 要 告诉 程序 做 什么 ,程序 自己 判断 怎么 做 ,从 而 提高 了 开发 
速度 。 

。 抽象 性 : 使 用 面向 对 象 的 方式 抽象 数据 。LINQ 通过 所 谓 的 O-R Mapping 方式 把 关 
系 型 转换 成 对 象 与 对 象 方式 描述 数据 。 

。 可 组 成 性 : LINQ 可 以 把 一 个 复杂 的 查询 拆 分 成 多 个 简单 查询 。LINQ 返回 的 结果 都 
是 基于 IEnumerable 一 T 之 接口 ,因此 能 对 查询 结果 继续 查询 。 

。 可 转换 性 : LINQ 能 把 一 种 数据 源 的 内 容 转 换 到 其 他 数据 源 ,方便 用 户 做 数据 移植 。 


13.1.2 LINOQ 提供 程序 


LINQ 提供 程序 将 LINQ 查询 映射 到 要 查询 的 数据 源 。 在 编写 LINQ 查询 时 ,提供 程序 
接受 该 查询 并 将 其 转换 为 数据 源 能 够 执行 的 命令 。 提 供 程序 还 将 源 中 的 数据 转换 为 组 成 查询 
结果 的 对 象 。 最 后 , 当 向 数据 源 发 送 更 新 时 , 它 能 够 将 对 象 转换 为 数据 。C# 包含 以 下 LINQ 
提供 程序 。 

1. LINQ to Objects 

使 用 LINQ to Objects 提供 程序 可 以 查询 内 存 中 的 集合 和 数组 。 如 果 对 象 支持 
IEnumerable 或 IEnumerable 一 T 过 接口 . 则 可 以 使 用 LINQ to Objects 提供 程序 对 其 进行 查 
询 。 用 户 可 以 通过 导入 System. Linq 命名 空间 来 启用 LINQ to Objects 提供 程序 ,默认 情况 
下 为 所 有 C# 项 目 导 入 该 命名 空间 。 

2. LINQ to XML 

使 用 LINQ to XML 提供 程序 可 以 查询 和 修改 XML, 既 可 以 修改 内 存 中 的 XML, 也 可 以 
从 文件 加 载 XML 以 及 将 XML 保存 到 文件 。 

3. LINQ to DataSet 

使 用 LINQ to DataSet 提供 程序 可 以 查询 和 更 新 ADO .NET 数据 集中 的 数据 ,可 以 将 
LINQ 功能 添加 到 使 用 数据 集 的 应 用 程序 中 ,以 便 简 化 和 扩展 对 数据 集中 的 数据 进行 查询 、 聚 
合 和 更 新 的 功能 。 

4. LINQ to SOL 

使 用 LINQ to SQL 提供 程序 可 以 查询 和 修改 SQL Server 数据 库 中 的 数据 ,这 样 就 可 以 
轻松 地 将 应 用 程序 的 对 象 模型 映射 到 数据 库 中 的 表 和 对 象 。 

C# 通 过 包含 对 象 关系 设计 器 (O/R 设计 器 ) 使 LINQ to SQL 更 加 易于 使 用 。 此 设计 器 
用 于 在 应 用 程序 中 创建 映射 到 数据 库 中 的 对 象 的 对 象 模型 。 

5. LINQ to Entities 

在 使 用 LINQ to Entities 时 ,LINQ 查询 在 后 台 转 换 为 SQL 查询 并 在 需要 数据 的 时 候 执 
行 , 即 开始 枚 举 结果 的 时 候 执行 。LINQ to Entities 还 为 获取 的 所 有 数据 提供 变化 追踪 ,也 就 
是 说 ,可 以 修改 查询 获得 的 对 象 ,然后 整 批 同时 把 更 新 提交 到 数据 库 。 

LINQ to DataSet、LINQ to SQL 和 LINQ to Entities 统称 为 LINQ to ADO .NET。 
图 13. 1 给 出 了 LINGQ 提供 程序 和 LINQ 数据 源 之 间 的 关系 。 


第 13 章 语言 集成 查询 一 一 LIN 


:NET 语言 集成 查询 (LINQ) 


ADO.NET LINQ 技 术 
LINQt LNQt | /LNGe | (LUNG LNQ 
Objects | DataSet SQL Entities XML 
对 象 数据 库 XML 


图 13.1 LINQ 提供 程序 和 LINQ 数 据 源 之 间 的 关系 


13.2 LINQ to Objects 


13.2.1 LINO 基本 操作 


LINQ 查询 通常 称 为 查询 表达 式 ”, 它 由 标识 查询 数据 源 的 查询 子 句 和 标识 查询 迭代 变 
量 的 查询 子 句 组 合 而 成 。 查 询 表达 式 还 可 以 包含 对 源 数 据 进行 排序 .筛选 .分 组 和 连接 的 指令 
或 要 应 用 于 源 数据 的 计算 。 查 询 表达 式 语法 类 似 于 SQL 的 语法 。 

LINQ 查询 分 为 3 个 基本 阶段 , 即 获 取 数 据 源 ,创建 查询 ,然后 执行 查询 。 

1. 获取 数据 源 

数据 源 是 LINQ 查询 对 象 。 例 如 ,可 以 定义 如 下 整 型 数组 numbers 作为 数据 源 : 

int [] numbers = new int[10]{1,2,3,4,5,6,7,8,9,10}; 

2. 创建 查询 

创建 查询 主要 是 定义 查询 表达 式 , 查 询 表 达 式 指定 如 何 从 数据 源 中 检索 信息 ,并 对 其 排 
序 、 分 组 和 结构 化 。 创 建 查 询 的 一 般 格式 如 下 : 


var 查询 变量 = from … where … select …; 


其 中 ,查询 变量 是 一 个 匿名 类 型 的 变量 ,并 使 用 查询 表达 式 对 其 初始 化 。from 子 句 指定 
数据 源 ,where 子 句 指定 筛选 条 件 ,select 子 句 指定 返回 元 素 的 类 型 。 例 如 : 


Var numQuery = 
from num in numbers 
where (num % 2) == 0 
select num; 
这 里 numQuery 是 一 个 匿名 类 型 的 查询 变量 ,查询 表达 式 是 从 numbers 数据 源 中 获取 偶 
数 元 素 。 
使 用 查询 表达 式 的 注意 事项 如 下 : 
。 子 句 必须 按照 一 定 的 顺序 出 现 。 
。 from 和 select 子 句 是 必须 有 的 ,select 子 句 在 表达 式 最 后 。 
。 其 他 子 句 是 可 选 的 。 
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3. 执行 查询 

在 LINQ 中 ,查询 变量 本 身 只 是 存储 查询 命令 ,创建 查询 仅仅 声明 查询 变量 ,并 不 执行 任 
何 操作 ,也 不 返回 任何 数据 ,只 有 执行 查询 才 会 执行 查询 变量 中 声明 的 查询 操作 ,并 返回 结果 
数据 ,这 称 为 延迟 执行 。 例 如 ,以 下 语句 执行 前 面 声 明 的 查询 : 


foreach (var x in numQuery) 
textBoxl. Text += x.ToString()+ " "; 


其 结果 是 在 textBoxl 中 显示 2 4 6 8 10。 它 的 执行 过 程 是 foreach 循环 一 次 , 便 从 
numQuery 中 取出 一 个 元 素 。 和 迭代 变量 num 保存 了 返回 的 序列 中 的 每 个 值 ( 一 次 保存 一 
个 值 ) 。 


13.2.2 LINO 查询 子 句 

1. from 子 句 

form 子 句 用 来 标识 查询 的 数据 源 , 以 及 用 于 分 别 引 用 数据 源 中 每 个 元 素 的 变量 ,这 些 变 
量 称 为 迭代 变量 。from 子 句 的 基本 格式 如 下 : 

from[ 类 型 ] 迭 代 变 量 in 数据 源 

其 中 ,“ 类 型 "是 可 选 的 ,如 果 不 指定 , 则 从 “数据 源 ” 推 断 迭 代 变 量 的 类 型 。 在 前 面 的 例子 
中 ,num 是 采用 匿名 类 型 隐 式 定义 的 ,也 可 以 显 式 定义 如 下 : 

Var numQuery = 

from int num in numbers 
where (num % 2) == 0 
select num; 

2. select 子 句 

在 查询 表达 式 中 ,select 子 句 可 以 指定 将 在 执行 查询 时 产生 值 的 类 型 。 该 子 句 的 结果 将 
基于 前 面 所 有 子 句 的 计算 结果 以 及 select 子 句 本 身 中 的 所 有 表达 式 。 查 询 表 达 式 必须 以 
select 子 句 或 group 子 句 结束 。 

LINQ 查询 返回 的 对 象 集合 称 为 源 系 列 , 源 系列 是 结构 化 的 数据 ,通常 由 一 个 或 多 个 元 素 
构成 ,每 个 元 素 由 一 个 或 多 个 字段 构成 。 通 过 select 子 句 指定 希望 在 源 系 列 中 出 现 的 字段 ,也 
可 以 选择 所 有 源 系列 字段 的 子 集 。 选 择 源 系 列 字段 子 集 主 要 有 下 面 两 种 方法 : 

@ 若 只 选择 源 系列 字段 的 一 个 字段 ,可 以 使 用 点 运算 。 

@ 若 选择 源 系列 的 多 个 字段 , 需 使 用 "select new { 和 迭代 变量 . 字段 1, 迭代 变量 .字段 2) 
的 格式 ,还 可 以 为 选择 的 源 系列 字段 定义 别名 ,其 基本 格式 为 "别名 一 迭代 变量 . 字段 ”。 

3. where 子 名 

where 子 句 指定 查询 的 筛选 条 件 。 筛 选 指 将 结果 集 限 制 为 只 包含 那些 满足 指定 条 件 的 元 
素 的 操作 , 它 又 称 为 选择 。where 子 句 的 基本 格式 如 下 : 

where 条 件 表达 式 

其 中 ,“ 条 件 表达 式 ” 是 必 选 项 , 它 确定 是 否 在 输出 结果 中 包含 源 系 列 中 当前 项 的 值 。 该 表 
达 式 的 计算 结果 必须 为 布尔 值 ,如 果 为 True, 则 在 查询 结果 中 包含 该 元 素 ,否则 从 查询 结果 中 
排除 该 元 素 。 一 个 查询 表达 式 可 以 包含 多 个 where 子 句 ,一 个 子 句 可 以 包含 多 个 谓词 子 表 
达 式 。 
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4. let 子 句 

在 查询 表达 式 中 ,存储 子 表达 式 的 结果 有 时 很 有 用 ,这 样 可 以 在 随后 的 子 句 中 使 用 。 用 户 
可 以 使 用 let 子 句 完成 这 一 工作 ,该 子 句 可 以 创建 一 个 新 的 迭代 变量 ,并 且 用 提供 的 表达 式 的 
结果 初始 化 该 变量 。 一 旦 用 值 初始 化 了 该 迭代 变量 , 它 就 不 能 用 于 存储 其 他 值 。 但 如 果 该 迭 
代 变 量 存储 的 是 可 查询 的 类 型 , 则 可 以 对 其 进行 查询 。let 子 句 的 基本 格式 如 下 : 

let 迭代 变量 = 表达 式 


例如 ,在 下 面 的 代码 中 以 两 种 方式 使 用 了 let, 第 一 次 创建 一 个 可 以 查询 自身 的 可 枚 举 类 
型 的 迭代 变量 word, 第 二 次 使 查询 对 迭代 变量 word 调用 一 次 ToLower 方法 ,产生 另 一 个 迭 
代 变量 w: 


string[ ] strings = {"A penny saved is a penny earned.", 
"The early bird catches the worm. ", 
"The pen is mightier than the sword. "}; 
var earlyBirdQuery = 
from sentence in strings 
let words = sentence.Split('') 
from word in words 
let w = word.ToLower() 


where w[0] == 'a'|| w[0] == 'e'||w[0] == 'i'|| w[0] == '0o'|| w[0] == 'u' 
select word; 
foreach (var v in earlyBirdQuery) // 在 文本 框 中 显示 "A is a earned. early is" 


TextBoxl. Text += v + "\r\n"; 
其 中 ,查询 变量 earlyBirdQuery 的 数据 来 自 word 迭代 变量 ,而 不 是 w 迭代 变量 。 如 果 改 
为 “select w”, 则 TextBoxl 中 显示 的 结果 如 图 13. 2 所 示 。 
5. orderby 子 句 


在 查询 表达 式 中 ,orderby 子 句 可 使 返回 序列 或 子 序列 TPR 
(组 ) 按 升序 或 降序 排序 。 用 户 可 以 指定 多 个 键 ,以 便 执行 大 localhost * 国光 


一 个 或 多 个 次 要 排序 操作 。 排 序 是 由 针对 元 素 类 型 的 默认 加 网 

比较 器 执行 的 ,默认 排序 顺序 为 升序 ,也 可 以 指定 自 定义 比 Ee 加 

较 器 。 但 是 ,只 能 通过 基于 方法 的 语法 使 用 它 。orderby 子 六 

句 的 基本 格式 如 下 : = = 
orderby 排序 表达 式 [ascending | descending] 图 13.2 TextBoxl 中 显示 的 结果 


其 中 ,排序 表达 式 " 是 必 选 项 ,指出 当前 查询 结果 中 的 
一 个 或 多 个 字段 ,用 于 标识 对 返回 值 进行 排序 的 方式 。 当 有 多 个 排序 字段 时 ,必须 以 逗号 分 
隔 。ascending 和 descending 关键 字 分 别 指定 对 字段 进行 升序 或 降序 排序 ,如 果 未 指定 , 则 默 
认 排 序 顺序 为 升序 。 排 序 字段 的 优先 级 从 左 到 右 依 次 降低 。 

6. join 子 句 

join 子 句 接受 两 个 数据 源 作为 输入 ,每 个 数据 源 中 的 元 素 都 必须 是 可 以 与 另 一 个 数据 源 
中 的 元 素 进 行 比较 的 字段 ,进行 这 样 比较 的 字段 称 为 键 (key)。join 子 句 使 用 特殊 的 equals 关 
键 字 比 较 指定 的 键 是 否 相等 。join 子 句 执行 的 所 有 连接 都 是 同等 连接 。join 子 句 的 基本 格式 
如 下 : 


join 迭代 变量 1 in 数据 源 1 on keyl equals key2[…] 
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其 中 ,“keyl equals key2” 用 于 标识 要 连接 的 键 ,必须 使 用 equals 运算 符 比较 要 连接 的 键 ， 
可 以 使 用 C# 的 逻辑 运算 符 来 标识 多 个 键 , 可 以 组 合 连接 条 件 。 
7. group by 子 句 
group by 子 句 对 查询 结果 的 元 素 进行 分 组 ,分 组 操作 基于 一 个 或 多 个 键 。group by 子 名 
的 基本 格式 如 下 : 
group 迭代 变量 by 分 组 的 键 
查询 结果 中 的 每 一 分 组 由 一 个 被 称 为 键 的 字段 区 分 ,每 一 个 分 组 本 身 是 可 枚 举 类 型 。 例 
如 ,以 下 代码 对 整 型 数组 numbers 中 的 整数 按 奇 偶 性 分 组 : 
int[ ] numbers = new int[10] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; 
var numQuery = 
from num in numbers 
group num by (num % 2) == 0; 
TextBoxl. Text = ""; 
foreach (var x in numQuery) 
{ ”TextBoxl.Text += "\rNn" + (x.Key ? "偶数 :" : "奇数 :"); 
foreach (var y in x) 
TextBoxl. Text += Y.ToString() + " "; 


} 个 | 全 hapy/localhost5316! 吕 
其 中 ,分 组 操作 键 值 为 Cnum %2) 一 0, 系 统 用 key 表 @ localhost x 


示 , 共 分 为 key 二 False( 奇 数组 ) 和 key 二 True( 偶 数组 )。 查 有 
询 结果 不 是 对 象 集合 ,而 是 对 象 集合 的 集合 。 通 过 两 重 | 人“ 
foreach 循环 获取 所 有 的 对 象 ,外 foreach 循环 遍历 各 个 分 
组 ,内 foreach 循环 遍历 分 组 内 的 对 象 。 执 行 上 述 代码 在 文 图 13.3 TextBoxl 中 显示 的 结果 
本 框 TextBoxl 中 显示 的 结果 如 图 13. 3 所 示 。 


13.2.3 方法 查询 

1. 方法 查询 概述 

在 LINQ 查询 中 大 多 数 查 询 都 是 使 用 LINQ 声明 式 查 询 语 法 ,在 编译 时 这 些 查 询 语 法 必 
须 转换 为 CLR 的 方法 调用 。 这 些 方法 调用 涉及 标准 查询 运算 符 , 如 Where、Select、GroupBy、 
Join、Max 和 Average, 可 以 直接 调用 这 些 方法 来 代替 查询 语法 ,在 LINQ 查询 中 使 用 方法 来 
代替 查询 语法 称 为 方法 语法 。 

查询 语法 和 方法 语法 的 语义 相同 ,但 是 查询 语法 更 简单 .更 易于 阅读 。 有 些 查询 必须 采用 
方法 调用 ,如 必须 使 用 方法 调用 来 检索 满足 指定 条 件 的 元 素 个 数 或 最 大 值 。 这 些 标准 查询 运 
算 符 包含 在 System. Linq 命名 空间 中 。 常 用 的 标准 查询 运算 符 及 其 说 明 如 表 13. 1 所 示 。 

表 13.1 常用 的 标准 查询 运算 符 


运算 符 说 明 

All 确定 序列 中 的 所 有 元 素 是 否 满足 条 件 

Any 确定 序列 是 否 包含 任何 元 素 

Average 计算 Decimal 值 序列 的 平均 值 .该 值 可 通过 调用 输入 序列 的 每 个 元 素 的 转换 函数 获取 
Count 返回 序列 中 的 元 素数 量 

Distinct 通过 使 用 默认 的 相等 比较 器 对 值 进 行 比较 ,返回 序列 中 的 非 重复 元 素 


ElementAt ”返回 序列 中 指定 索引 处 的 元 素 
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续 表 
运算 符 说 明 
First 返回 序列 中 的 第 一 个 元 素 
GroupBy 根据 指定 的 键 选择 器 函数 对 序列 中 的 元 素 进行 分 组 
Intersect 通过 使 用 默认 的 相等 比较 器 对 值 进行 比较 生成 两 个 序列 的 交集 
Join 基于 默认 的 相等 比较 器 对 两 个 序列 的 元 素 进行 连接 
Last 返回 序列 的 最 后 一 个 元 素 
LongCount ”返回 一 个 Int64 表示 序列 中 的 元 素 的 总 数量 
Max 返回 泛 型 序列 中 的 最 大 值 
Min 返回 泛 型 序列 中 的 最 小 值 
OrderBy 根据 键 按 升序 对 序列 的 元 素 排序 
Reverse 反 转 序列 中 元 素 的 顺序 
Select 将 序列 中 的 每 个 元 素 投影 到 新 表 中 
SelectMany 将 序列 的 每 个 元 素 投 影 到 IEnumerable 一 T 二 并 将 结果 序列 合并 为 一 个 序列 
Skip 跳 过 序列 中 指定 数量 的 元 素 , 然 后 返回 剩余 的 元 素 
Sum 计算 Decimal 值 序列 的 和 ,这 些 值 是 通过 对 输入 序列 中 的 每 个 元 素 调用 转换 函数 得 来 的 
Where 基于 谓词 筛选 值 序列 


2. 标准 查询 运算 符 的 参数 类 型 


标准 查询 运算 符 的 参数 类 型 有 两 种 , 即 Lambda 表达 式 参数 形式 和 使 用 委托 参数 形式 。 


例如 ,以 下 代码 采用 Lambda 表达 式 参数 形式 获取 numbers 中 的 偶数 ， 


int[ ] numbers = new int[10] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; 
var numQuery = numbers. Where(num => num % 2 == 0).OrderBy(n => n); 
TextBoxl. Text = ""; 
foreach (var x in numQuery) 
TextBoxl.Text += x.ToString()+""; 


3. into 子 句 


用 户 可 以 使 用 into 上 下 文 关键 字 创 建 一 个 临时 标识 符 , 以 便 将 group、join 或 select 子 句 


的 结果 存储 到 新 的 标识 符 中 。 此 标识 符 本 身 可 以 是 附加 查询 命令 的 生成 器 。 
例如 ,有 以 下 代码 ， 


int[ ] numbers = new int[10] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; 
var numQuery = 

from num in numbers 

group num by (num % 2) == 0 into numl 

select new { f1 = numl.Key, f2 = numl.Count() }; 
TextBoxl.Text = ""; 
foreach (var x in numQuery) 

TextBoxl.Text += (x.f1? "偶数 :”: "奇数 :") + x.f2.ToString() + "\r\n"; 


迭代 变量 num 从 数据 源 numbers 中 获取 所 有 元 素 , 按 


奇 、 偶 性 分 组 ,并 将 结果 存放 到 临时 标识 符 numl 中 .select | napwocanostssla Pp 
子 句 选取 每 个 分 组 的 键 值 和 元 素 个 数 。 在 执行 时 文本 框 的 > 
显示 结果 如 图 13.4 所 示 。 偶数 :5 败 

4. 聚合 运算 符 


标准 查询 运算 符 中 有 一 部 分 是 聚合 运算 符 , 如 Sum、 图 13.4 TextBoxl 中 显示 的 结果 
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Max、Min、Count 和 Average 等 。 聚 合 运算 符 是 从 值 集合 计算 单个 值 , 而 不 是 一 系列 结果 ,所 
以 使 用 它们 会 强制 立即 执行 查询 ,而 不 是 延迟 执行 。 

【 例 13.1】 在 D 盘 ASP.NET 目录 中 建立 一 个 ch13 的 子 目 录 , 将 其 作为 网 站 目录 ,然后 
创建 一 个 WebForml 网 页 ,其 功能 是 说 明 LINQ to Objects 中 聚合 运算 符 的 使 用 方法 。 

解 : 其 步骤 如 下 。 

Oa 启动 Visual Studio 2012 。 

@ 选择 "文件 | 新 建 | 网 站 ”命令 ,出 现 * 新 建 网 站 ”对话 框 , 然 后 选择 "ASP.NET 空 网 站 ” 
模板 ,选择 “Web 位 置 ”为 “文件 系统 ”, 单 击 “ 浏 览 ” 按 钮 ,选择 “D:\ASP.NET\ch13” 目 录 , 单 击 
“确定 ”按钮 ,创建 一 个 空 的 网 站 ch13。 

@ 在 chl3 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForml 空 网 页 。 

@ 在 该 网 页 上 放置 一 个 多 行文 本 框 TextBoxl, 设 置 字体 和 颜色 属性 ,并 设计 如 下 事件 
过 程 : 

protected void Page_Load( object sender, EventArgs e) 

{ int[] numbers = new int[10] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; 

var numQuery = from num in numbers 

where num > 3 

select num; 
TextBoxl.Text = "个 数 : " + numQuery. Count().ToString() + "\r\n"; 
TextBoxl.Text += "最 大 值 : ”+ numQuery. Max().ToString() + "\r\n"; 
TextBoxl.Text += "最 小 值 : ”+ numQuery.Min().ToString() + "\r\n"; 
TextBoxl.Text += "平均 值 : " + numQuery. Average().ToString() + "\r\n"; 
TextBoxl.Text += "总 和 : " + numQuery. Sum().ToString(); 

} 

上 述 代码 使 用 聚合 运算 符 求 元 素 个 数 和 最 大 值 等 。 

@ 单 击 工具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,在 文本 框 中 显示 的 结果 如 图 13. 5 


所 示 。 
|B rupliocalhosts316; P ~ 
六 localhost x 国 加 


数 :7 
最 大 值 : 10 入 
最 小 值 : 4 
平均 值 = 7 v 
总 和 : 49 


图 13.5 WebForml 网 页 运行 界面 
13.3 LINQ to XML 


13.3.1 XML 文 档 


XML 即 可 扩展 标记 语言 (eXtensible Markup Language) ,XML 的 定义 如 下 : XML 指 可 
扩展 标记 语言 ; XML 是 一 种 标记 语言 ,很 类 似 HTML; XML 的 设计 宗旨 是 传输 数据 ,而 非 显 
示 数 据 ; XML 标记 没有 被 预定 义 , 用 户 需 要 自行 定义 标记 ; XML 被 设计 为 具有 自我 描述 性 ; 
XML 是 W3C 的 推荐 标准 。 
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XML 注重 对 数据 结构 和 数据 意义 的 描述 ,实现 了 数据 内 容 和 显示 样式 的 分 离 , 而 且 是 与 
平台 无 关 的 。 采 用 XML 格式 的 文档 称 为 XML 文档 。XML 文档 是 数据 的 载体 ,可 以 使 用 任 
意 Web 技术 来 显示 数据 。 由 于 世界 各 大 计算 机 公司 的 积极 参与 ,XML 正 日 益 成 为 基于 互联 
网 的 数据 格式 的 新 一 代 的 标准 。 存 放 XML 文档 的 文件 称 为 XML 文件 。 

XML 与 HTML 既 相 似 又 有 区 别 , 最 大 的 不 同 是 XML 被 设计 用 来 传输 和 存储 数据 ,而 
HTML 被 设计 用 来 显示 数据 。XML 不 是 对 HTML 的 替代 ,而 是 对 HTML 的 补充 。 

注意 : 通常 将 XML 文件 放 入 App_Data 目录 时 ,XML 文件 就 具有 了 正确 的 权限 ,可 以 允 
许 ASP.NET 在 运行 时 对 该 文件 进行 读 / 写 操作 。 此 外 ,将 文件 保留 在 App_Data 目录 中 可 防 
止 在 浏览 器 中 查看 这 些 文件 ,因为 App_Data 目录 被 标记 为 不 可 浏览 。 

【 例 13.2】 在 ch13 网 站 中 创建 一 个 存放 学 生 信 息 的 student. xml 文件 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012。 

@ 打开 ch13 网 站 , 右 击 项 目 名 ch13 ,在 出 现 的 快捷 菜单 中 选择 “添加 | 添加 ASP.NET 文 
件 夹 |App_Data ”命令 ,创建 一 个 App_Data 目录 。 

@ 选择 “网 站 | 添加 新 项 "命令, 出现 “添加 新 项 -ch13” 对 话 框 ,在 中 间 列 表 中 选择 “XML 
文件 "模板 ,修改 文件 名 为 student. xml( 保 存在 App_Data 目录 中 ), 单 击 “ 添 加 ”按钮 , 即 创建 
了 一 个 仅 包含 XML 指令 的 student. xml 文件 ,在 该 文件 中 输入 如 图 13.6 所 示 的 代码 。 


《9?xml version="”1.0” encoding="utf-8” ?> 《学 生 > 
《学 生 表 > 《学 号 >6</ 学 号 > 

《学 生 > 《姓名 > 张 军 </ 姓名 > 
《学 号 >1《/ 学 号 > 《性 别 > 男 </ 性 别 > 
《姓名 > 王 华 </ 姓 名 > 《民族 > 汉族 </ 民 族 > 
《性 别 > 女 </ 性 别 > 《 班 号 ?09001</ 班 号 > 
《民族 > 汉族 </ 民 族 > 《/ 学 生 > 
《 班 号 >09001</ 班 号 > 《学 生 > 

</ 学生 > 《学 号 ?8</ 学 号 > 

《学 生 > 《姓名 > 马 棋 </ 姓 名 > 
《学 号 >2</ 学 号 > 《性 别 > 男 </ 性 别 > 
《姓名 > 孙 丽 </ 姓名 > 《民族 > 回族 </ 民 族 > 
《性 别 > 女 </ 性 别 > 《 班 号 ?09002</ 班 号 > 
《民族 > 满族 </ 民 族 > 《/ 学 生 > 
《 班 号 ?09002</ 班 号 > 《/ 学 生 表 > 

《/ 学 生 > 

《学 生 > 
《学 号 ?3</ 学 号 > 
《姓名 > 李兵 </ 姓 名 > 
《性 别 > 男 </ 性 别 > 
《民族 > 汉族 </ 民 族 > 
《 班 号 ?09001</ 班 号 > 

《/ 学 生 > 


图 13.6 student. xml 文档 


@ 单 击 工具 栏 中 的 国 按 钮 保存 文件 。 

下 面 介 绍 XML 文档 中 的 几 个 概念 。 

。 XML 元 素 : 指 的 是 从 ( 且 包 括 ) 开 始 标记 直到 ( 且 包 括 ) 结 束 标记 的 部 分 。 元 素 可 包含 
其 他 元 素 、 文 本 或 者 两 者 的 混合 物 。 例 如 在 student. xml 中 ,一 学 生 表 二 和 志学 生 二 
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都 拥有 元 素 内 容 , 因 为 它们 包含 了 其 他 元 素 , 到 学 号 之 .所 姓名 之 等 元 素 只 有 文本 内 
容 。 被 包含 在 其 他 元 素 中 的 元 素 称 为 子 元 素 。 

。 XML 属性 : XML 元 素 可 以 在 开始 标记 中 包含 属性 ,类 似 HTML。 例如 在 二 person 
sex 一 "female" 盖 …</person 过 中 ,所 定义 的 二 person 二 元 素 包含 sex 属性 , 取 值 为 
"female" 。 但 是 在 XML 中 应 该 尽量 避免 使 用 属性 ,如 果 信息 感觉 起 来 很 像 数 据 , 那 么 
最 好 使 用 子 元 素 格式 。 

。 XML DOM(Document Object Model ,文档 对 象 模型 ) : DOM 定义 了 访问 和 操作 XML 
文档 的 标准 方法 。DOM 把 XML 文档 作为 树 结构 来 查看 ,能 够 通过 DOM 树 访问 所 有 
元 素 , 可 以 修改 或 删除 它们 的 内 容 , 并 创建 新 的 元 素 。 该 树 结构 中 的 元 素 、 它 们 的 文本 
以 及 它们 的 属性 都 被 认为 是 XML 结 点 。 


13.3.2 使 用 LINQ to XML 


LINQ to XML 是 内 存 中 的 XML 编程 接口 ,开发 人 员 使 用 它 可 以 轻松 有 效 地 操作 和 修 
改 XML 文档 。 
1. 常用 的 XML 类 
LINQ to XML 包含 多 个 类 ,位 于 System. Xml. Lingq 命名 空间 ,其 中 最 重要 的 3 个 类 是 
XDocument、XElement 和 XAttribute。 
(1) XDocument 类 
XDocument 类 表示 一 个 XML 文档 。XDocument 类 的 常见 属性 和 方法 如 表 13. 2 所 示 。 
表 13.2 XDocument 类 的 常见 属性 和 方法 
类 别 | 名 称 说 明 
FirstNode 获取 此 结 点 的 第 一 个 子 结 点 
LastNode 获取 此 结 点 的 最 后 一 个 子 结 点 
NextNode 获取 此 结 点 的 下 一 个 同 级 结 点 
属性 | NodeType 获取 此 结 点 的 结 点 类 型 


Parent 获取 此 XObject 的 父 级 XElement, 其 中 XObject 表示 XML 树 中 的 结 点 或 属性 
PreviousNode | 获取 此 结 点 的 上 一 个 同 级 结 点 
Root 获取 此 文档 的 XML 树 的 根 元 素 


从 文件 创建 新 XDocument。 例 如 “XDocument doc 二 XDocument. Load ( "abc. 
xml"); "语句 从 abc. xml 文件 创建 一 个 XML 文档 

将 一 个 XML 文档 存放 到 XML 文件 中 。 例 如 “doc. Save("abc. xml");” 语 句 将 
XDocument 类 对 象 doc 存储 到 abc. xml 文件 中 


Load 
方法 


Save 


(2) XElement 类 

XElement 类 表示 一 个 XML 元 素 。XElement 类 的 常见 属性 和 方法 如 表 13. 3 所 示 。 

(3) XAttribute 类 

XAttribute 类 表示 一 个 XML 属性 。XAttribute 类 的 常见 属性 和 方法 如 表 13. 4 所 示 。 

2. LINQ to XML 的 基本 查询 

LINQ to XML 基本 查询 与 LINQ to Objects 十 分 相似 ,只 是 LINQ to XML 的 数据 源 是 
XML 文档 ,需要 结合 常用 的 XML 类 实现 查询 。 
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表 13.3 XElement 类 的 常见 属性 和 方法 


类 别 | 名 称 说 明 
FirstAttribute | 获取 此 元 素 的 第 一 个 属性 
FirstNode 获取 此 结 点 的 第 一 个 子 结 点 
LastAttribute | 获取 此 元 素 的 最 后 一 个 属性 
LastNode 获取 此 结 点 的 最 后 一 个 子 结 点 
属性 | Name 获取 或 设置 此 元 素 的 名 称 
NextNode 获取 此 结 点 的 下 一 个 同 级 结 点 
Parent 获取 此 XObject 的 父 级 XElement, 其 中 XObject 表示 XML 树 中 的 结 点 或 属性 


PreviousNode 


获取 此 结 点 的 上 一 个 同 级 结 点 


Value 获取 或 设置 此 元 素 的 串 连 文本 内 容 
从 文件 加 载 XElement。 例 如 “XElement root 二 XElement. Load("abc. xml");”, 其 
中 root 为 该 加 载 的 XML 文档 的 根 元 素 
方法 可 获取 具有 指定 XName 的 第 一 个 ( 按 文档 顺序 ) 子 元 素 , 如 果 没 有 元 素 具有 指定 的 名 
ES 称 , 则 返回 null, 其 中 XName 表示 XML 元 素 或 属性 的 名 称 
Elements 按 文档 顺序 返回 此 元 素 或 文档 的 子 元 素 集合 
表 13.4 XAttribute 类 的 常见 属性 和 方法 
类 别 名 称 说 明 
NextAttribute 获取 父 元 素 的 下 一 个 属性 
NodeType 获取 此 结 点 的 结 点 类 型 
属性 Parent 获取 此 XObject 的 父 级 XElement 
Previous Attribute 获取 父 元 素 的 上 一 个 属性 
Value 获取 或 设置 此 属性 的 值 
男 流 Remove 从 此 属性 的 父 元 素 中 移 除 它 
SetValue 设置 此 属性 的 什 
【 例 13.3】 在 chl3 网 站 中 设计 一 个 WebForm2 网 页 ,其 功能 是 说 明 LINQ to XML 的 简 
单 使 用 方法 。 


解 : 其 步骤 如 下 。 
@ 启动 Visual Studio 2012 。 
@ 在 chl3 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm2 空 网 页 。 


@ 在 本 网 页 
过 程 : 


上 添加 一 个 多 行文 本 框 TextBoxl ,设置 字体 和 颜色 属性 ,并 设计 如 下 事件 


using System. Xml. Ling; 

protected void Page_Load(object sender, EventArgs e) 

{ XElement root = XElement.Load(MapPath("\\App_Data\\student.xml")); 
var myqueryl = fromm in root.Elements(" 学 生 ") 


var myquery2 


where (string)m. Element(" 班 号 ") =="09001" 
select m; 


= from m in root.Elements(" 学 生 ") 


where (string)m. Element(" 民族 ") != "汉族 " 
select m; 


TextBoxl.Text = "09001 班 人 数 : ”+ myquery1.Count().ToString(); 
TextBoxl1.Text +="\r\n 少数 民族 人 数 : ”+ myquery2.Count().ToString(); 
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@ 单 击 工 具 栏 中 的 p> Imternet Explorer 按钮 运行 本 网 页 ,在 文本 框 中 显示 的 结果 如 图 13.7 


所 示 。 
3. 将 XML 查询 绑 定 到 GridView 控件 


(后 j 图 |@neymoanosssp 对 于 返回 XElement 集合 的 LINQ 查询 ,在 GridView 
localhost * 控件 中 显示 时 需要 建立 两 者 字段 之 间 的 映射 关系 ,这 是 通 
区 白 过 选择 源 系 列 字 段子 集 ( 即 select new 子 句 ) 来 实现 的 。 


【 例 13.4】 在 ch1l3 网 站 中 设计 一 个 WebForm3 网 
页 ,其 功能 是 说 明 将 XML 查询 绑 定 到 GridView 控件 的 
图 13.7 WebForm2 网 页 运行 界面 方法 。 


解 : 其 步骤 如 下 。 


@ 启动 Visual Studio 2012 。 
@ 在 chl3 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm3 空 网 页 。 
@ 在 本 网 页 上 添加 一 个 GridViewl 控件 ,设置 字体 和 颜色 属性 ,并 设计 如 下 事件 过 程 : 


using System. Xm]. Linq7 
protected void Page_Load( object sender, EventArgs e) 
{ varmyquery = fromm 
in XElement.Load(MapPath("\\App_Data\\student. xml" ) ).Elements(" 学 生 ") 
Select new 
‘ 学 号 = (string)m.Element(" 学 号 ")， 
姓名 = (string)m.Element(" 姓 名 ")， 
性 别 = (string)m.Element(" 性 别 ")， 
民族 = (string)m.Element(" 民族" ),， 
班 号 = ( string)m.Element(" 班 号 " ) 


}; 
GridViewl. DataSource = myquery; 
GridView1. DataBind(); 
} 
@ 单 击 工 具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ， J 
在 GridViewl 控件 中 显示 的 结果 如 图 13. 8 所 示 。 图 13.8 ”WebForm3 网 页 运行 界面 
4. LINQ to XML 的 复杂 操作 
LINQ to XML 支持 查询 .过 滤 、 分 组 和 连接 等 复杂 操作 ,其 语法 格式 与 LINQ to Objects 
相似 。 
【 例 13.5】 在 chl3 网 站 中 设计 一 个 WebForm4 网 页 ,其 功能 是 说 明 连 接 操 作 的 使 用 
方法 。 
解 : 其 步骤 如 下 。 
@ 启动 Visual Studio 2012 。 
@ 为 了 实现 连接 操作 ,在 App_Data 目录 中 添加 一 个 包含 以 下 内 容 的 score. xml 文件 : 
<?xml version= "1.0" encoding = "utf 一 8" ?> 
< 成 绩 表 > 
< 成 绩 > < 学 号 > 1 </ 学 号 > < 课程 名 >C 语言 </ 课 程 名 > ”< 分 数 > 80 </ 分 数 > </ 成 绩 > 
< 成 绩 > < 学 号 > 1 </ 学 号 > < 课程 名 > 数据 结构 </ 课 程 名 > < 分 数 > 87 </ 分 数 > </ 成 绩 > 
< 成 绩 > < 学 号 > 2 </ 学 号 > < 课程 名 >C 语言 </ 课 程 名 > ”< 分 数 > 70 </ 分 数 > </ 成 绩 > 
< 成 绩 > < 学 号 > 2 </ 学 号 > < 课程 名 > 数据 结构 </ 课 程 名 > < 分 数 > 52 </ 分 数 > </ 成 绩 > 
< 成 绩 > < 学 号 > 3 </ 学 号 > < 课程 名 >C 语言 </ 课 程 名 > ”< 分 数 > 89 </ 分 数 > </ 成 绩 > 
< 成 绩 > < 学 号 > 3</ 学 号 > < 课程 名 > 数据 结构 </ 课 程 名 > < 分 数 > 84 </ 分 数 > </ 成 绩 > 
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< 成 绩 > < 学 号 > 6 </ 学 号 > < 课程 名 >C 语言 </ 课 程 名 > < 分 数 > 90 </ 分 数 > </ 成 绩 > 

< 成 绩 > < 学 号 > 6 </ 学 号 > < 课程 名 > 数据 结构 </ 课 程 名 > < 分 数 > 95 </ 分 数 > </ 成 绩 > 

< 成 绩 > < 学 号 > 8 </ 学 号 > < 课程 名 >C 语言 </ 课 程 名 > < 分 数 > 88 </ 分 数 > </ 成 绩 > 

< 成 绩 > < 学 号 > 8 </ 学 号 > < 课程 名 > 数据 结构 </ 课 程 名 > < 分 数 > 86 </ 分 数 > </ 成 绩 > 
</ 成 绩 表 > 


@ 在 chl3 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm4 空 网 页 。 
@ 在 本 网 页 上 添加 一 个 GridViewl 控件 ,设置 字体 和 颜色 属性 ,并 设计 如 下 事件 过 程 : 


using System. Xm]. Ling; 
protected void Page_Load(object sender, EventArgs e) 
{ var myquery = fromm in 
XElement.Load(MapPath("\\App_Data\\student. xml" ) ). Elements(" 学生 ") 
join g in XElement. Load( MapPath("\\App_Data\\score. xml" ) ) .Elements(" 成 绩 ") 
on (int)m. Element ("学 号 ") equals (int)g.Element(" 学 号 ") 
select new 
{ ”学 号 = (string)m.Element(" 学 号 "), 
姓名 = (string)m.Element(" 姓 名 ")， 
= (string)g.Element(" 课 程 名 ")， 
分 数 = (float)g.Element(" 分 数 ") 
}; 
GridView1. DataSource = myquery; 
GridView1. DataBind(); 
} 


@ 单 击 工 具 栏 中 的 Internet Explorer 按钮 运行 本 网 页 ,在 GridViewl 控件 中 显示 的 结果 如 
图 13.9 所 示 。 
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图 13.9 WebForm4 网 页 运行 界面 


13.4 LINQ to DataSet 


使 用 LINQ to DataSet 可 以 更 快 ,更 容易 地 查询 在 DataSet 对 象 中 缓存 的 数据 。 具 体 而 
言 , 通 过 使 开发 人 员 能 够 使 用 编程 语言 本 身 而 不 是 通过 使 用 单独 的 查询 语言 来 编写 查询 ， 
LINQ to DataSet 可 以 简化 查询 。 

在 使 用 LINQ to DataSet 查询 数据 集 时 ,首先 要 填充 DataSet, 然后 才能 使 用 LINQ to 
DataSet 来 查询 DataSet 对 象 。 向 DataSet 中 加 载 数据 有 多 种 方法 ,如 使 用 DataAdapter 对 象 


384 
P.NET 4.5 动态 网 站 设计 教程 一 一 基于 C# 5. 0 十 SQL Server 2012 


等 。LINQ to DataSet 可 以 对 DataSet 中 的 单个 表 ( 即 DataTable 对 象 ) 执行 查询 ,也 可 以 通过 
使 用 Join 和 GroupJoin 标准 查询 运算 符 对 多 个 表 执 行 查询 。 

在 使 用 LINQ to DataSet 进行 数据 集 操作 时 ,LINQ 不 能 直接 从 DataTable 数据 集 对 象 中 
查询 (LINQ 查询 仅 适用 于 实现 IEnumerable 接口 或 IQueryable 接口 的 数据 源 ), 因 为 该 数据 
集 对 象 不 支持 LINQ 查询 ,所 以 需要 使 用 AsEnumerable 方法 返回 一 个 泛 型 的 对 象 以 支持 
LINQ 的 查询 操作 。 

后 面 的 示例 使 用 了 第 12 章 创 建 的 Stud 数据 库 , 在 这 里 启动 SQL Server 2012, 建 立 
student 和 score 表 之 间 的 外 键 关 系 如 图 13. 10 所 示 。 


图 13.10 建立 student 和 score 表 之 间 的 关系 


为 了 方便 使 用 ,打开 ch13 网 站 中 的 Web. config 文件 ,在 二 configuration 之 节 中 添加 以 下 
连接 字符 串 ， 
<connectionStrings > 
<add name = "myconnstring" 
connectionString = "Data Source= LCB— PC\SQLEXPRESS; Initial Catalog = Stud; 
User ID= sa;Password = 12345" 
providerName = "System. Data. SqlClient" /> 
</connectionStrings > 


下 面 通过 一 个 简单 的 示例 说 明 LINQ to DataSet 的 使 用 方法 。 

【 例 13.6】 在 ch1l3 网 站 中 设计 一 个 WebForm5 网 页 ,采用 LINQ to DataSet 按 学 号 降 
序 显示 所 有 学 生 记 录 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012。 

@ 在 chl3 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm5 空 网 页 。 

图 在 其 中 放置 一 个 GridViewl 控件 和 一 个 Labell 控件 ,设置 它们 的 字体 和 颜色 ,并 设计 
如 下 事件 过 程 : 


using System. Data; 
using System. Data. SqlClient; 
protected void Page_Load( object sender, EventArgs e) 
{ string mystr = System.Configuration.ConfigurationManager. 
ConnectionStrings[ "myconnstring" ]. ToString(); 
SqlConnection myconn = new SqlConnection(); 
myconn. ConnectionString = mystr; 
myconn. Open( ); 
DataSet myds = new DataSet(); 
SqlDataAdapter myda = new SqlDataAdapter("SELECT * FROM student",myconn); 
myda. Fill(myds, "student"); 
myconn. Close( ); 
DataTable mydt = myds.Tables["student"]; 
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var myquery = 
from m in mydt.AsEnumerable() 
orderby m. Field< string >(" 学 号 ") descending 
select new 


{ ”学 号 = m.Field< string>(" 学 号 ")， 
姓名 = m. Field< string >(" 姓 名 ")， 
性 别 = m. Field< string >(" 性 别 ")， 
民族 = m. Field< string >(" 民 族 ")， 
班 号 = m. Field< string >(" 班 号 ") 


}; 
GridViewl. DataSource = myquery; 
GridViewl. DataBind(); 
Labell. Text = "总 人 数 :" + myquery. Count().ToString(); 
h 


注意 : 使 用 Field 二 T 沁 方法 获取 数据 集 的 字段 名 ， PE 
其 中 的 泛 型 参数 本 中 指定 的 数据 类 型 必须 与 基础 值 的 (Oe eaerss p-o 
类 型 相 匹配 ,否则 将 引发 InvalidCastException; 指定 的 @ localhost * 
字段 名 也 必须 与 DataSet 中 的 字段 名 相 匹 配 , 否 则 将 引 
发 ArgumentException。 在 这 两 种 情况 下 ,异常 都 是 在 
执行 查询 期 间 的 运行 时 数据 枚 举 时 引发 的 。 

@ 单 击 工具 栏 中 的 Pp Internet Explorer 按钮 运行 本 网 
页 ,在 GridView1 控件 中 显示 的 结果 如 图 13. 11 所 示 。 

需要 说 明 的 是 ,LINQ to DataSet 是 在 ADO. NET 
2.0 中 引入 的 ,新 的 ASP .NET 4. 5 仅仅 保留 了 这 一 图 13.11 WebForm5 网 页 运行 界面 
功能 。 


13.5 LINQ to SQL 


在 LINQ to SQL 中 ,关系 数据 库 的 数据 模型 映射 到 用 开发 人 员 所 用 的 编程 语言 表示 的 对 
象 模型 。 当 应 用 程序 运行 时 ,LINQ to SQL 会 将 对 象 模 型 中 的 语言 集成 查询 转换 为 SQL , 然 
后 将 它们 发 送 到 数据 库 进 行 执 行 。 当 数据 库 返 回 结果 时 ,LINQ to SQL 会 将 它们 转换 回 编程 
语言 处 理 的 对 象 。LINQ to SQL 的 功能 类 位 于 System. Data. Linq 命名 空间 。 


13.5.1 使 用 O/R 映射 器 


上 述 转换 是 一 个 复杂 的 过 程 ,实际 上 ,Visual Studio 提供 了 用 户 Object Relation(O/R) 映 
射 器 , 它 可 以 快速 地 将 基于 SQL 的 数据 源 映射 为 .NET Framework 的 CLR 元 素 , 之 后 就 可 以 
使 用 LINQ to SQL 查询 数据 了 。 

在 第 12 章 12. 5. 3 节 中 简单 介绍 过 O/R 映射 器 ,使 用 它 可 以 创建 一 个 上 下 文 对 象 ,将 
LinqDataSourcel 控件 的 ContextTypeName 属性 指定 为 这 个 上 下 文 对 象 ,就 可 以 将 该 控件 作 
为 GridView 控件 的 数据 源 。 

下 面 进一步 讨论 O/R 映射 器 。 设计 一 个 后 面 示例 中 使 用 的 LINQ to SQL 上 下 文 类 
DataClassesDataContext 的 过 程 如 下 : 

Oa 在 chl3 网 站 中 选择 “网 站 | 添加 新 项 "命令, 出现 “添加 新 项 -ch13” 对 话 框 ,在 中 间 列 表 
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中 选择 “LINQ to SQL 类 ”, 保 持 默 认 文 件 名 DataClasses. dbml, 单 击 “ 添 加 ”按钮 。 

@ 出 现 创 建 DataClasses. dbml 的 界面 , 单 击 中 部 的 “服务 器 资源 管理 器 ” 超 链接 ,左边 出 
现 服务 器 资源 管理 器 窗口 。 由 于 Web. config 文件 中 有 一 个 连接 字符 串 myconnstring, 所 以 
“数据 连接 ” 结 点 下 有 一 个 “myconnstring(ch13)” 选 项 。 

@ 展开 “myconnstring(ch13)” 选 项 ,将 student 和 score 两 个 表 拖 放 到 设计 界面 中 ,如 
图 13. 12 所 示 。 由 于 在 前 面 13. 4 节 中 已 建立 了 它们 之 间 的 外 键 关系 ( 见 图 13. 10), 图 中 两 个 
表 之 间 的 连 线 表示 这 种 关系 。DataClasses. designer. cs 文件 中 的 以 下 代码 表示 了 这 种 关系 : 


[global : :System. Data. Ling. Mapping. AssociationAttribute( Name = "student_score"， 
Storage = "_score", ThisKey = "学 号 "，OtherKey = "学 号 ")] 
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图 13.12 添加 两 个 表 后 的 LINQ to SQL 设计 界面 


@ 单 击 工 具 栏 中 的 畏 按 钮 保存 文件 。 

此 时 在 解决 方案 资源 管理 器 的 App_Code 目录 中 产生 3 个 文件 , 即 DataClasses. dbml、 
DataClasses. dbml. layout 和 DataClasses. designer. cs, 后 两 个 文件 从 属于 前 一 个 文件 。 

说 明 : 使 用 O/R 映射 器 的 目的 是 产生 上 下 文 类 ,其 名 称 是 由 LINQ to SQL 自动 生成 的 ， 
如 上 述 文件 名 为 DataClasses. dbml, 产 生 的 上 下 文 类 为 DataClassesDataContext。 本 节 后 面 
的 示例 都 使 用 该 类 。 


13.5.2 使 用 LINO to SOL 

1. 查询 数据 

在 上 下 文 类 创建 好 后 ,使 用 LINQ to SQL 查询 数据 的 方法 与 LINQ to Objects 十 分 相似 。 

【 例 13.7】 在 ch1l3 网 站 中 设计 一 个 WebForm6 网 页 ,采用 LINQ to SQL 按 学 号 降序 显 
示 所 有 学 生 记录 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012 。 

@ 在 chl3 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm6 空 网 页 。 

@ 在 其 中 放置 一 个 GridViewl 控件 和 一 个 Labell 控件 ,设置 它们 的 字体 和 颜色 ,并 设计 
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如 下 事件 过 程 : 


protected void Page_ Load( object sender, EventArgs e) 
{ DataClassesDataContext dc = new DataClassesDataContext(); 
Var myquery = from m in dc. student 
orderby m. 学 号 descending 
select m; 
GridViewl. DataSource = myquery; 
GridViewl. DataBind() ; 


Labell. Text = "总 人 数 :”+ myquery. Count().ToString(); 
} 


@ 单 击 工 具 栏 中 的 p> Inmternet Explorer 按钮 运行 本 网 页 ,在 GridViewl 控件 中 显示 的 结果 如 
图 13.11 所 示 。 


下 面 的 示例 包含 连接 、 分 组 .排序 和 聚合 函数 的 应 用 。 

【 例 13.8】 在 chl3 网 站 中 设计 一 个 WebFormy7 网 页 ,采用 LINQ to SQL 实现 各 种 复杂 
的 查询 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012 。 

@ 在 chl3 网 站 添加 一 个 代码 隐藏 页 模型 的 WebFormy7 空 网 页 。 

@ 在 其 中 放置 一 个 GridViewl 控件 和 4 个 命令 按钮 ,设置 它们 的 字体 和 颜色 ,并 设计 如 
下 事件 过 程 : 

protected void Buttonl_Click(object sender, EventArgs e) 

{ // 求 所 有 分 数 

DataClassesDataContext dc = new DataClassesDataContext(); 


var myquery = from st in dc.student 
join sc in dc. score on st. 学 号 equals sc. 学 号 
Select new 
{ ”学 号 = st. 学 号 , 姓名 = st. 姓 名 ,， 
课程 名 = sc. 课程 名 , 分 数 = sc. 分数 
}; 
GridView1. DataSource = myquery; 
GridView1. DataBind(); 
' 
protected void Button2_Click(object sender, EventArgs e) 
{ ”VU/ 求 各 课程 平均 分 
DataClassesDataContext dc = new DataClassesDataContext(); 
var myquery = from sc in dc.score 
group sc by sc. 课程 名 into gou 


select new 
{ ”课程 名 = gou. Key, 
平均 分 = gou. Average(sc => sc. 分 数 ) 


}; 
GridView1. DataSource = myquery; 
GridView1. DataBind(); 
} 
protected void Button3_Click(object sender, EventArgs e) 
{ ”// 求 >83 平 均 分 课程 
DataClassesDataContext dc = new DataClassesDataContext(); 
Var myquery = from sc in dc. score 
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group sc by sc. 课程 名 into gou 


select new 
{ ”课程 名 = gou. Key, 
平均 分 = gou. Average(sc => sc. 分 数 ) 


}; 
var myqueryl = from avgsc in myquery 
where avgsc. 平均 分 > 83 
select avgsc; 
GridViewl. DataSource = myqueryl; 
GridView1. DataBind(); 

} 

protected void Button4_Click(object sender, EventArgs e) 

{ // 求 所 有 学 生平 均 分 并 按 平 均 分 递减 排序 
DataClassesDataContext dc = new DataClassesDataContext(); 
var myquery = from st in dc.student 

join sc in dc. score on st. 学 号 equals sc. 学 号 
select new 
{ ”学 号 = st. 学 号 , 姓名 = st. 姓 名 , 
课程 名 = sc. 课程 名 , 分 数 = sc. 分 数 
}; 
var myqueryl = from sc in myquery 
group sc by sc. 姓名 into gou 
orderby gou. Average( sc => sc. 分 数 ) descending 
Select new 
{ ”姓名 = gou. Key, 
平均 分 = gou. Average(sc => sc. 分 数 ) 
}; 
GridView1. DataSource = myqueryl; 
GridView1. DataBind() ; 
| 


@ 单 击 工具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 , 单 击 各 个 命令 按钮 时 的 显示 结果 分 
别 如 图 13. 13 一 图 13. 16 所 示 。 


< 人 EC 
@ localhost x 


1 王 华 (语言 80 
1 玉 华 ” 教 所 结构 。 “87 OG vocanonssis p- c| ME 
2 各 丽 (语言 70 三 localhost x 
2 孙 丽 ”数据 结构 52 来 所 有 分 至 人 录 各 课程 平均 分 
mE 一 一 
3 李兵 ”数据 结构 84 
6 张 军 (语言 90 
6 张 军 ”数据 结构 95 C 语 言 83.4 
| B ““ 蕊 棋 “” C 语 言 a 数据 结构 30.8 
8 86 


图 13.13 WebForm?7 网 页 运行 界面 一 图 13.14 WebForm7 网 页 运行 界面 二 
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sb 日 原 localhost 其 
MD OG eyennortsslep-c| Ns 孙 所 有 分 并 。 | 未 各 吝 程 平均 分 
@ localhost x (未 所 有 学生 平均 分 
| ee 
《R299 和 均 分 这 程 | 求 所 有 学 生平 均 分 张 军 92.5 
= 马 棋 87 | 
李兵 86.5 
Cc 语言 3 王 华 83.5 | 
孙 而 61 
13.15 ”WebForm7 网 页 运行 界面 三 13.16 WebFormy7 网 页 运行 界面 四 
2. 插入 数据 


使 用 LINQ to SQL 插入 数据 时 ,只 需要 创建 要 插入 的 新 对 象 ,并 将 其 添加 到 对 象 集合 中 。 
在 LINQ 上 下 文 类 (如 DataClassesDataContext) 中 提供 了 下 面 两 个 方法 。 

。 InsertOnSubmit 方法 : 把 单个 对 象 作为 参数 ,将 它 添加 到 对 象 集合 中 。 

。 InsertAllOnSubmit 方法 : 把 一 个 集合 作为 参数 ,将 该 集合 添加 到 对 象 集合 中 。 

在 添加 对 象 后 ,LINQ to SQL 还 需要 额外 的 一 步 来 调用 上 下 文 类 的 SubmitChanges 方 
法 。 该 方法 告诉 LINQ to SQL 执行 Insert 操作 。 

例如 ,以 下 代码 在 student 表 中 插入 一 条 学 号 为 *101” 的 新 记录 : 


protected void Page_Load( object sender, EventArgs e) 
{ DataClassesDataContext dc = new DataClassesDataContext(); 
student st = new student{ 学 号 = "101", // 创 建 一 个 学 生 对 象 
姓名 =“" 章 海 ", 性 别 =" 男 "， 
民族 =" 汉 族 ", 班 号 = "09003"}; 


dc. student. InsertOnSubmit (st); // 插 入 到 集合 中 
dc. SubmitChanges( ) // 提 交 插 入 
} 
3. 更 新 数据 


使 用 LINQ to SQL 更 新 数据 与 插入 数据 类 似 。 首 先 获 得 要 更 新 的 对 象 , 可 以 使 用 要 更 新 
的 集合 的 Single 方法 ,该 方法 根据 其 输入 参数 从 集合 中 返回 要 更 新 的 对 象 。 如 果 有 多 个 记录 
匹配 ,Single 方法 只 返回 第 一 条 匹配 的 记录 。 

有 了 要 更 新 的 记录 之 后 ,只 需 修 改 对 象 的 属性 值 , 再 调用 上 下 文 类 的 SubmitChanges 方 
法 即 可 。 

例如 ,以 下 代码 在 student 表 中 将 学 号 为 *101” 的 记录 的 姓名 更 新 为 “成 功 ”: 


protected void Page_Load( object sender, EventArgs e) 
' DataClassesDataContext dc = new DataClassesDataContext(); 
var st = dc.student.Single(m=>m. 学 号 =="101"); // 查 找 


st. 姓名 =“" 成 功 "; // 更 新 

dc. SubmitChanges( ); // 提 交 更 新 
} 
4. 删除 数据 


在 LINQ 上 下 文 类 (如 DataClassesDataContext) 中 提供 了 两 个 方法 用 于 从 数据 源 中 删除 
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数据 。 
。 DeleteOnSubmit 方法 : 把 单个 对 象 作为 参数 ,从 对 象 集合 中 删除 该 对 象 。 
。， DeleteAllOnSubmit 方法 : 把 一 个 集合 作为 参数 ,从 对 象 集合 中 删除 该 集合 中 的 所 有 
记录 。 
首先 获得 要 删除 的 对 象 ,最 后 调用 上 下 文 类 的 SubmitChanges 方法 提交 删除 操作 。 
例如 ,以 下 代码 在 student 表 中 删除 学 号 为 "101? 的 记录 : 
protected void Page_Load(object sender, EventArgs e) 
{ DataClassesDataContext dc = new DataClassesDataContext(); 
var st = dc.student.Single(m=>m. 学 号 =="101"); // 查 找 
dc. student. DeleteOnSubmit (st); 7/ 删除 
dc. SubmitChanges( ); // 提 交 删 除 
} 


又 如 ,以 下 代码 在 student 表 中 删除 所 有 班 号 为 “09003” 的 学 生 记录 : 


protected void Page_Load( object sender, EventArgs e) 
{ DataClassesDataContext dc = new DataClassesDataContext(); 
var myquery = from m in dc. student 
where m. 班 号 == "09003" 


select m; // 查 找 
dc. student. DeleteAllOnSubmit (myquery); // 删 除 
dc. SubmitChanges( ); // 提 交 删 除 


13.6 LINQ to Entities 


LINQ to Entities 允许 开发 人 员 使 用 C# 等 给 实体 框架 概念 模型 编写 查询 。LINQ to 
SQL 查询 最 终 会 创建 在 后 台数 据 库 中 执行 的 SQL, 而 LINQ to Entities 将 LINQ 查询 转换 为 
ADO.NET 实体 框架 (Entity Framework,EF) 能 理解 的 命令 树 查询 ,对 实体 框架 执行 这 些 查 
询 , 返 回 可 同时 由 实体 框架 和 LINGQ 使 用 的 对 象 。 


13.6.1 ADO .NET 实体 框架 


ADO.NET 实体 框架 是 ADO.NET 中 的 一 套 支 持 开发 面向 数据 的 软件 应 用 程序 的 技术 ， 
是 支持 开发 面向 数据 的 应 用 程序 的 对 象 关系 映射 器 (Object Relational Mapper, ORM) ,使 开 
发 人 员 可 以 采用 特定 于 域 的 对 象 和 属性 (如 客户 和 客户 地 址 ) 的 形式 使 用 数据 ,而 不 必 自 己 考 
虑 存储 这 些 数据 的 基础 数据 库 表 和 列 。 也 就 是 说 ,使 用 ADO. NET 实体 框架 可 以 把 许多 数据 
库 对 象 ( 如 表 ) 转 换 成 可 以 在 代码 中 访问 的 .NET 对 象 ,然后 就 可 以 在 查询 中 或 者 直接 在 数据 
绑 定 中 使 用 这 些 对 象 。 因 此 借助 实体 框架 开发 人 员 在 处 理 数 据 时 能 够 以 更 高 的 抽象 级 别 工 
作 , 并 且 能 够 以 相 比 传统 应 用 程序 更 少 的 代码 创建 和 维护 面向 数据 的 应 用 程序 。 

为 了 使 用 LINQ to Entities, 需 要 创建 实体 框架 数据 模型 。 如 同 使 用 O/R 映射 器 创建 
LINQ to SQL 类 一 样 ,Visual Studio 提供 了 实体 数据 模型 向 导 ( 即 对 象 关系 映射 器 ) 用 于 创建 
实体 框架 。 

为 了 不 和 前 面 的 示例 冲突 ,本 节 单 独 在 DD 盘 ASP.NET 目录 中 建立 一 个 ch13-1 的 子 目 
录 , 将 其 作为 ch13-1 网 站 (采用 “ASP.NET 空 网 站 ”模板 ) ,并 像 13. 4 节 那 样 在 Web. config 文 


391 
第 13 章 语言 集成 查询 一 一 LIN 
件 中 放 入 同样 的 myconnstring 连接 字符 串 定义 。 

设计 一 个 后 面 示例 使 用 的 LINQ to Entities 上 下 文 类 StudEntities 的 过 程 如 下 : 

@ 在 chl3-1 网 站 中 选择 网 站 | 添加 新 项 "命令, 出现" 添加 新 项 -ch13-1” 对 话 框 ,在 中 间 
列表 中 选择 "ADO.NET 实体 数据 模型 ”, 保 持 默 认 文件 名 Model. edmx, 如 图 13. 17 所 示 , 然 
后 单 击 * 添 加 ”按钮 ,将 启动 实体 数据 模型 向 导 , 将 生成 的 文件 放 在 App_Code 目录 中 。 


搜索 已 安装 模板 (Ctrl+ 日 


类 型 : Visual C# 


用 于 创建 ADOJNET 实体 数据 模型 的 项 目 
项 


SY Coffeescript 
加 Dynamic Data 字段 
钢 Ersxpbconet sm 


后 nnn cals 


13.17 “添加 新 项 -ch13-1” 对 话 框 


@ 出 现 “ 选 择 模 型 内 容 ” 对 话 框 ,选择 从 数据 库 生 成 ”如 图 13. 18 所 示 , 然 后 单 击 “ 下 一 
步 ?按钮 。 


图 13. 18 “选择 模型 内 容 ” 对 话 框 
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@ 出 现 “ 选 择 您 的 数据 连接 ”对 话 框 ,选择 的 设置 如 图 13. 19 所 示 , 然 后 单 击 “ 下 一 步 ” 按 钮 。 


metadata=resy/VAPp_CodeModelesdliresy/"/APp_Code Modelssdl 
resy/VAPP_Code ModeLmstprovider= connection 
string="data source=LCB-PC\SQLEXPRESS;initial catalog=Stud;user 

id=sa;password="*™""",MultipleActiveResultSets=True:App=EntityFramework" 


回 将 Web.Config 中 的 实体 连接 设置 另存 为 (S): 


StudEntities 


EE | 


图 13.19 “选择 您 的 数据 连接 ”对 话 框 


@ 出 现 ” 选择 您 的 数据 库 对 象 和 设置 对 话 框 ， 展开 “ 表 ” 结 点 ,选中 student 和 score 表 , 如 
图 13. 20 所 示 , 单 击 “ 完 成 "按钮 ,出现 的 ADO.NET 实体 数据 模型 设计 器 界面 如 图 13. 21 所 示 。 


图 13. 20 “选择 您 的 数据 库 对 象 和 设置 ”对话 框 
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DY localhost 60420 - Microsoft Visual sudiofE 5 饼 芝 启动 (Cl+Q) P -= ox 
文件 有 。 回馈 (E) 视图 (V) ”网 站 (S) ”生成 (8) ”调式 (D) ”团队 (M) ”工具 (D 。 测 式 (S) ”分析 (N) ”窗口 (W) 帮助 (H) 
-9 -故国 中 了 -CS - IntemetExplorer- Debug - 再 - 
Modeledm EBD + x Modelt ~” 解 方 实 资 源 管 理 血 ~ 4x 
008 eo-e8alo| xD 
准 幸 站 志方 安 资 源 管理 器 (Ctrl+:) bs 
同 解 方 衬 “localhost_ 50420”(1 个 项 目 ) 


‘ 并 字 studEntities (ch13-1) 连 按 
错开 ~9x 图 双 天 


4 
' 
而 
加 
3 
人 
刘 
EE 
» 
0 
» 


版 专 11.00.2100 
关 Microsoft SQL Servw 


工具 箱 ”服务 器 资源 符 理 器 4 » 


图 13.21 ADO.NET 实体 数据 模型 设计 器 界面 


@ 单 击 工 具 栏 中 的 图 按钮 保存 文件 。 

此 时 ,在 解决 方案 资源 管理 器 的 App_Code 目录 中 添加 了 Model. edmx 和 两 个 .tt 文件 。 
Model. edmx 是 一 个 XML 文件 ,用 于 定义 数据 库 模 型 的 架构 ,Model. Designer. cs 是 一 个 C# 
代码 文件 ,包含 了 要 用 于 LINQ to Entities 查询 的 数据 类 型 。 另 外 还 在 网 站 中 创建 了 一 个 Bin 
目录 ,在 其 中 添加 了 ADO.NET 实体 数据 模型 需要 的 程序 集 和 XML 文件 。 

上 述 操作 将 Stud 数据 库 的 数据 模型 映射 为 对 象 模型 ,所 创建 的 对 象 模型 为 上 下 文 类 
StudEntities, 并 在 Web. config 文件 的 二 connectionStrings 二 节 中 自动 添加 如 下 连接 字 
符 串 ， 

<add name = "StudEntities” 

connectionString = "metadata= res://* /App_Code.Model.csdl| 

res://* /App_Code. Model. ssdl| res://* /App_Code. Model. msl; 

provider = Systenm. Data. SqlClient; 

provider connection string = &quot;data source = LCB — PC\SQLEXPRESS; 

initial catalog= Stud;user id= sa;password = 12345; MultipleActiveResultSets = True; 

App = EntityFramework&quot;" 

providerName = "System. Data. EntityClient" /> 

通常 ,Model. Designer. cs 的 内 容 是 隐藏 的 ,而 且 这 个 文件 会 被 数据 模型 重新 生成 ,因此 
不 应 该 也 不 必要 手工 去 修改 这 个 文件 。 如 果 要 看 到 它 的 代码 ,在 图 13. 21 的 属性 窗口 中 将 “ 代 
码 生 成 策略 ”属性 由 “无 ”修改 为 “默认 值 ”, 青 双击 Model. Designer. cs' 则 在 代码 编辑 窗口 中 显 
示 其 代码 。 

Model. Designer. cs 文件 主要 包含 两 段 代 码 区 域 , 即 上 下 文 和 实体 。 

上 下 文 区 域 定义 的 第 一 个 类 从 ObjectContext 派生 ,其 名 称 为 StudEntities。 这 个 类 的 构 
造 函 数 连接 到 所 生成 模型 的 数据 库 . 或 者 可 以 指定 连接 字符 串 连 接 到 其 他 数据 库 ( 必 须 具 有 相 
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同 的 架构 ,否则 模型 无 法 工作 )。 
实体 类 用 于 把 数据 库 表 的 记录 映射 到 C# 对象, 每 个 实体 对 象 包含 如 下 内 容 。 


。 工厂 方法 : 可 以 通过 默认 的 构造 函数 或 工厂 方法 创建 实体 对 象 新 实例 。 工 厂 方法 的 


参数 是 需要 的 字段 , 它 是 试图 保存 数据 元 素 时 防止 架构 错误 的 好 办 法 。 
。 字段 属性 : 实体 对 象 为 它们 派生 的 数据 库 表 的 每 个 列 包含 一 个 字段 属性 。 


。 导航 属性 : 如 果 数 据 模型 中 包含 了 外 键 关系 ,实体 对 象 就 会 包含 帮助 访问 关联 数据 的 


导航 属性 。 


实体 类 被 声明 为 分 部 类 ,因此 可 以 创建 扩展 功能 ,在 重新 生成 数据 模型 时 它 不 会 被 覆盖 。 


13.6.2 使 用 LINO to Eniities 


实际 上 ,LINQ to Entities 没有 提供 任何 不 能 用 ADO. NET 代码 、 自 定义 对 象 .LINQ to 


Objects 实现 的 特性 ,但 有 时 出 于 某 些 原因 而 需要 考虑 使 用 LINQ to Entities。 


。 更 少 的 代码 : 不 必 编 写 查询 数据 库 的 ADO.NET 代码 ,可 以 通过 一 个 工具 生成 需要 的 


数据 类 。 


。 灵活 的 查询 能 力 : 不 必 拼 次 SQL 语句 ,而 是 使 用 LINQ 查询 模型 。 一 致 的 查询 模型 可 


访问 众多 不 同 的 数据 源 ( 从 数据 库 到 XML) 。 


。 变更 追踪 以 及 批量 更 新 : 可 以 对 查询 的 数据 进行 多 项 修改 并 提交 批量 更 新 ,这 不 需要 


编写 任何 ADO. NET 代码 。 
下 面 以 前 面 创建 的 上 下 文 类 StudEntities 为 例 介绍 LINQ to Entities 的 应 用 。 
1. LINQ to Entities 查询 
(1) 基本 查询 
用 户 可 以 使 用 select、from、where 和 orderby 等 基本 子 句 进行 查询 。 


【 例 13.9】 在 chl3-1 网 站 中 设计 一 个 WebForm8 网 页 ,采用 LINQ to Entities 按 班 号 顺 


序 显示 所 有 男 学 生 的 记录 。 
解 : 其 步骤 如 下 。 
@ 启动 Visual Studio 2012 。 
@ 在 chl3-1 网 站 添加 一 个 代码 隐藏 页 模型 的 WebFormg 空 网 页 。 
@ 在 其 中 放置 一 个 GridViewl 控件 ,设置 其 字体 和 颜色 ,并 设计 如 下 事件 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
{ StudEntities dc = new StudEntities(); 
var myquery = from m in dc. student 
where m. 性 别 ==" 男 " 
orderby m. 班 号 
Select m; 
GridView1. DataSource = myquery.ToList(); 
GridView1. DataBind(); 


需要 注意 的 是 ,myquery 是 一 个 存储 查询 ,其 值 不 是 集合 ,而 是 一 个 运算 表达 式 。 


[System. Data. Entity. Infrastructure. DbQuery < student >] = 
{SELECT [Extent1].[ 学 号 ] AS [学 号 ]，[Extent1].[ 姓 名 ] AS [姓名 ], 
[Extent1]. [性别 ] AS [性 别 ],，[Extent1].[ 民 族 ] RS [民族 ], 


已 


;的 值 


第 13 章 语言 集成 查询 一 一 LIN 
[Extent1].[ 班 号 ] RS [ 班 号 ] 
FROM [dbo]. [ student] AS [Extent1] 
WHERE ' 男 ' = [Extent1].[ 性 别 ] 
ORDER BY [Extent1].[ 班 号 ] ASC} 


不 能 直接 将 其 赋 给 GridView1. DataSource, 需 要 使 用 ToList 方法 ,这 样 才 能 成 为 对 应 的 
集合 。 

@ 单 击 工 具 栏 中 的 Pp Internet Explorer 按钮 运行 本 网 = "mm 
页 ,在 GridView1 控件 中 显示 的 结果 如 图 13. 22 所 示 。 ocahosto02 PO 

(2) 使 用 聚合 函数 > 

使 用 聚合 函数 可 以 在 一 个 集合 上 进行 数学 计算 。 
例如 ,以 下 代码 在 GridViewl 控件 中 显示 各 个 民族 的 
学 生 人 数 : 


StudEntities dc = new StudEntities(); 
var myquery = from m in dc. student 图 13.22 WebForm8 网 页 运行 界面 
group m by m. 民族 into gou 
select new 
{ 民族 
人 数 


gou. Key, 
gou. Count() 


}; 
GridView1. DataSource = myquery. ToList(); 
GridView1. DataBind( ); 


(3) 使 用 导航 属性 

实体 类 包含 导航 属性 ,导航 属性 是 由 数据 库 上 的 外 键 关 系 转换 而 来 的 ,通过 导航 属性 可 以 
在 数据 模型 间 方 便 地 移动 。 

【 例 13.10】 在 ch13-1 网 站 中 设计 一 个 WebForm9 网 页 ,采用 LINQ to Entities 统计 每 
个 学 生 的 选课 数 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012 。 

@ 在 ch13-1 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForm9 空 网 页 。 

@ 在 其 中 放置 一 个 GridViewl 控件 ,设置 其 字体 和 颜色 ,并 设计 如 下 事件 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
{ Studgntities dc = new StudEntities(); 
Var myquery = from st in dc. student 
let sc = from scl in st. score 


where st. 学 号 == scl. 学 号 


select scl 

Select new 
{ ”学 号 = st. 学 号 , 
姓名 = st. 姓名, 


选课 数 = sc. Count() 
}; 
GridView1. DataSource = myquery.ToList(); 
GridView1. DataBind(); 
} 


在 上 述 代 码 中 ,st 为 student 表 对 应 的 数据 集 ,由 于 student 表 和 score 表 之 间 是 一 对 多 的 
关系 ,因此 通过 st 可 以 导航 到 score。 
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@ 单 击 工具 栏 中 的 Pimiemet Bplerer 按钮 运行 本 网 页 ， 豆 
在 GridViewl 控件 中 显示 的 结果 如 图 13. 23 所 示 。 Ere 

2. 数据 库 操作 * 国 

用 户 可 以 通过 ADO. NET 实体 框架 数据 模型 插入 、 更 
新 和 删除 数据 库 记 录 。 

(1) 插入 

和 LINQ to SQL 的 插入 操作 一 样 ,首先 要 创建 一 个 要 
插入 的 记录 ,用 Add 添加 到 集合 中 ,最 后 调用 SaveChanges 
方法 提交 插入 。 图 13. 23 ”WebForm9 网 页 运行 界面 

例如 ,以 下 代码 在 student 表 中 插入 一 个 新 记录 : 


StudEntities dc = new StudEntities(); 

student st = new student 

ho", // 创 建 一 个 学 生 对 象 
姓名 =" 章 海 ", 性 别 =" 男 "， 


中 
中 


民族 = "汉族 "， 班 号 = "09003" 
}s 
dc. student. Add( st); // 插 入 到 集合 中 
dc. SaveChanges( ); // 提 交 插 入 


(2) 更 新 

在 更 新 操作 时 ,首先 查找 要 更 新 的 记录 ,再 修改 相应 的 字段 值 , 最 后 调用 SaveChanges 方 
法 提交 更 新 。 

例如 ,以 下 代码 在 student 表 中 将 学 号 为 *101” 的 记录 的 姓名 改 为 “成功”: 


StudEntities dc = new StudEntities(); 


var st = dc. student. Single(m =>m. 学 号 == "101"); // 查 找 

st. 姓 名 = "成功 "; // 更 新 
dc. SaveChanges( ); // 提 交 更 新 
(3) 删除 


在 删除 操作 时 ,首先 查找 要 删除 的 记录 ,再 用 Remove 方法 从 集合 中 删除 该 记录 ,最 后 调 
用 SaveChanges 方法 提交 删除 。 如 果 删 除 多 个 记录 ,要 一 个 一 个 地 删除 。 
例如 ,以 下 代码 在 student 表 中 将 "09003” 班 的 所 有 记录 删除 : 


StudEntities dc = new StudEntities(); 
Var myquery = from m in dc. student 
where m. 班 号 == "09003" 


select m; // 查 找 
foreach( student st in myquery) 
dc. student. Remove( st); // 删 除 
dc. SaveChanges()7 // 提 交 删 除 


13.6.3 ”EntityDataSource 控件 


EntityDataSource 控件 表示 ASP. NET 应 用 程序 中 数据 绑 定 控件 的 实体 数据 模型 , 它 和 
上 下 文 类 (如 StudEntities) 一 起 使 用 ,以 便 实 现 LINQ to Entities 查询 。EntityDataSource 控 
件 提供 的 属性 有 Select( 获 取 或 设置 定义 要 包含 在 查询 结果 中 的 属性 的 投影 )、Where( 获 取 或 
设置 指定 如 何 筛选 查询 结果 的 Entity SQL 表达 式 ) 和 OrderBy( 获 取 或 设置 指定 如 何 对 查询 


【 例 13. 111 


结果 进行 排序 的 Entity SQL 表达 式 ) 等 。 
的 基本 使 用 方法 。 
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解 : 其 步骤 如 下 。 


@ 在 ch13-1 网 站 添加 一 个 代码 隐藏 页 模型 的 WebForml0 空 网 页 。 


到 EntityDataSourcel 控件 的 代码 如 下 :; 


@ 在 其 中 放置 一 个 GridViewl 控件 ,设置 其 字体 和 颜色 ,再 放置 一 个 EntityDataSourcel 
控件 ,进入 其 “配置 数据 源 ” 对 话 框 ,配置 ObjectContext 如 图 13. 24 所 示 , 单 击 “ 下 一 步 ” 按 钮 。 


出 现 “ 配 置 数据 选择 ”对 话 框 ,配置 数据 选择 如 图 13. 25 所 示 , 单 击 * 完 成 "按钮 。 在 源 视图 中 看 


<asp:EntityDataSource ID = "EntityDataSourcel" runat = "server" 


ConnectionString = "name = StudEntities" DefaultContainerName = "StudEntities" 
EnableFlattening = "False" EntitySetName = "student" 
</asp:EntityDataSource> 


Select = "it. [学 号 ],，it.[ 姓 名],it. [性别]，it. [民族 ]，it.[ 班 号 ]"> 


图 13. 24 


“配置 ObjectContext” 对 话 框 
@ 设置 GridView1 控件 的 数据 源 为 EntityDataSourcel 控件 。 
表 中 的 所 有 学 生 记 录 。 


@ 单 击 工具 栏 中 的 p> Intemet Explorer 按钮 运行 本 网 页 ,在 GridViewl 控件 中 将 显示 student 


从 .NET Framework 3. 5 开始 ,LINQ to SQL 被 LINQ to Entities 替代 ,Microsoft 公司 


宣布 不 再 提供 LINQ to SQL 更 新 ,但 仍然 被 支持 。LINQ to Entities 具有 许多 新 特征 ,是 
.NET 应 用 程序 开发 的 主流 方向 之 一 ,读者 可 以 阅读 相关 资料 进一步 了 解 。 


语言 集成 查询 一 一 LIN 
在 ch13-1 网 站 中 设计 一 个 WebForml0 网 页 ,说明 EntityDataSource 控件 
O@ 启动 Visual Studio 2012。 
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练习 题 13 


. LINQ 有 哪些 优点 ? 

. 通常 有 哪 几 种 LINQ 提供 程序 ?它们 操作 的 数据 源 分 别 是 什么 ? 
. LINQ 查询 过 程 分 为 哪些 阶段 ”分 别 完成 什么 工作 ? 

. 在 LINQ 中 查询 语法 和 方法 请 法 有 什么 异同 ? 

.有 如 下 数组 : 


int[ ] numbers = new int[10] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; 


网 页 中 有 一 个 文本 框 TextBoxl 和 一 个 命令 按钮 Buttonl, 用户 单 击 Buttonl 时 在 
TextBoxl 中 显示 所 有 偶数 ,请 采用 LINQ to Objects 设计 相应 的 事件 处 理 过 程 。 
【参考 答案 】 


protected void Button1_Click(object sender, EventArgs e) 
var numQuery = from num in numbers 
where num% 2==0 
select num; 
foreach (var x in numQuery) 
TextBoxl. Text += x.ToString() + " "; 


an 证 


6. 在 chl3 网 站 中 添加 一 个 类 文件 Classl. cs, 包 含 如 下 两 个 类 : 


public class Student // 声 明 Student 类 
{ ”public int 学 号 ; // 定 义 公 有 字段 


public string 姓名 ; 
public string 性 别 ; 
public string 民族 ; 
public string 班 号 ; 
public Student(int xh, string xm, string xb, string mz, string bh) 


{ 学 号 = xh; 姓名 = xm; 
性 别 = xb; 民族 = mz; 班 号 = bh; 
. 
}; 
public class Score // 声 明 Score 类 
{ ”public int 学 号 ; // 定 义 公 有 字段 


public string 课程 名 ; 
public int 分 数 ; 
public Score( int xh, string kcm, int fs) 


}; 
设计 一 个 网 页 ,网 页 中 有 一 个 文本 框 TextBoxl 和 两 个 命令 按钮 (Buttonl 和 Button2) ,其 
中 定义 有 如 下 数据 源 : 


ArrayList arrListl = new ArrayList(); // 定 义学 生动 态 数组 
ArrayList arrList2 = new ArrayList(); // 定 义学 生成 绩 动态 数组 
protected void Page_Load( object sender, EventArgs e) 
{ Student[] st ={ 
new Student(1," 王 华 ", " 女 ", "汉族 ", "09001")， 
new Student(2," 孙 丽 "," 女 ", "满族 ", "09002")， 
new Student(3," 李 明 "," 男 ", "汉族 ", "09001")， 
new Student(6," 张 军 ", " 男 ", "汉族 ", "09001")， 
new Student(8," 马 棋 "," 男 ", "回族 ", "09002") }; 
foreach (Student s in st) // 向 arrListl 中 添加 5 个 学 生 记录 
arrListl. Add( s); 
Score[] sc ={ 
new Score(1,"C 语言 ",80),new Score(2,"C 语言 ",70)， 
new Score(3,"C 语言 ",89),new Score(6,"C 语言 ",90)， 
new Score(8,"C 语言 ",88),new Score(1," 数 据 结构 ",87)， 
new Score(2, "数据 结构 ", 52), new Score(3, "数据 结构 ",84)， 
new Score(6, "数据 结构 ",95), new Score(8, "数据 结构 ",86) }; 
foreach (Score c in sc) // 向 arrList2 中 添加 10 个 学 生成 绩 记 录 
arrList2. Add(c); 
} 


在 网 页 运行 时 单 击 Buttonl 命令 按钮 的 结果 如 图 13. 26 所 示 ; 单 击 Button2 命令 按钮 的 
结果 如 图 13. 27 所 示 。 请 采用 LINQ to Objects 设计 这 些 事 件 处 理 过 程 。 


|G pwocahossltap -ce] 万 云 可 DG nanocanossslts p - c] 万 到 而 
@ localhost x a 三 localhost x 
学 号 姓名 性 别 民族 班 号 学 号 课程 名 。 分数 
1 王 华 党 汉族 09001 八 6 C 语 言 。 90 A 
3 李 明 男 汉族 09001 3 Cc 语言 。 89 
6 张 军 男 汉族 09001 8 Cc 语言 ”88 
2 孙 丽 女 满族 09002 1 Cc 语言 。 80 
8 己 模 男 回族 09002 2 Cc 语言 ”70 
| 6 数据 结构 95 
| 中 : 教 据 结构 87 | 
日 孝 据 结构 86 
| 3 数据 结构 84 
vl 2 数据 结构 52 
Buttonl Button2 | | 
| 


图 13.26 第 6 题 网 页 的 运行 界面 一 图 13.27 第 6 题 网 页 的 运行 界面 二 
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【参考 答案 】 


protected void Buttonl_ Click(object sender, EventArgs e) 
{ var mydata = from Student st in arrListl orderby st. 班 号 select st; 
TextBoxl.Text = "学 号 \t 姓 名 \t 性 别 \t 民族 \t 班 号 \r\n"; 
foreach (var x in mydata) 
TextBoxl.Text += x. 学 号 .ToString() + "\t" + x. 姓 名 + "\t" 
+ x. 性 别 + "\t”+ x. 民 族 + "\t”+ x. 班 号 + "\r\n"; 
} 
protected void Button2_Click(object sender, EventArgs e) 
{ var mydata = from Score sc in arrList2 orderby sc. 课程 名 , sc. 分 数 descending select sc; 
TextBoxl.Text = "学 号 \t 课 程 名 \t 分 数 \r\n"; 
foreach (var x in mydata) 
TextBoxl.Text += x. 学 号 .ToString() +"\t” + x. 课 程 名 + "\t" 
+ X. 分 数 . ToString() + "\r\n"; 
} 


7. 修改 第 6 题 的 网 页 ,在 网 页 运行 时 单 击 Buttonl 命令 按钮 的 结果 如 图 13. 28 所 示 ; 单 
击 Button2 命令 按钮 的 结果 如 图 13. 29 所 示 。 请 采用 LINQ to Objects 设计 这 些 事 件 处 理 
过 程 。 


EE 


图 13.28 第 7 题 网 页 的 运行 界面 一 图 13.29 第 7 题 网 页 的 运行 界面 二 


【参考 答案 】 


Pprotected void Button1_Click(object sender, EventArgs e) 
{ varmydata = from Student st in arrListl group st by st. 班 号 ; 
TextBoxl. Text = ""; 
foreach (var x in mydata) 
{ TextBoxl.Text += " 班 号 : " + x.Key + "\r\n"; 
TextBoxl. Text += "学 号 \t 姓名 \t 性 别 \t 民族 \z\n"; 
foreach (var y in x) 
TextBoxl. Text += y. 学 号 .ToString() + "\t” + y. 姓 名 + "\t" 
+ 了 性别 + "\t”+ 了 .民族 + "\r\n"; 
} 
protected void Button2_Click(object sender, EventArgs e) 
{ varmydata = from Score sc in arrList2 group sc by sc. 课程 名 ; 
TextBoxl.Text = ""; 
foreach (var x in mydata) 


第 13 章 语言 集成 查询 一 一 LIN 


{ ”TextBoxl. Text += "课程 名 : " + x.Key + "\r\n"; 
TextBoxl.Text += "学 号 \t 分 数 \r\n"; 
foreach (var y in x) 
TextBoxl. Text += y. 学 号 .ToString() + "\t”+ y. 分 数 .ToString() + "\r\n"; 


} 


8. 修改 第 6 题 的 网 页 ,在 网 页 运行 时 单 击 Buttonl 命令 按钮 的 结果 如 图 13. 30 所 示 ; 单 
击 Button2 命令 按钮 的 结果 如 图 13. 31 所 示 。 请 采用 LINQ to Objects 设计 这 些 事件 处 理 
过 程 。 


课程 名 。 最 高 分 课程 名 。 平均 分 
c 语 言 ”90 Ci 语言 ”83.4 
数据 结构 95 ‖ | 数据 结构 80.8 


v| 


[Late [etal 


图 13.30 第 8 题 网 页 的 运行 界面 一 图 13.31 第 8 题 网 页 的 运行 界面 二 


【参考 答案 】 


protected void Button1_Click(object sender, EventArgs e) 
{ varmydata = from Score sc in arrList2 
group sc by sc. 课程 名 into fs 
select new 
{ fl = fs.Key, 
f2 = fs.Max(sc => sc. 分 数 ) 
}; 
TextBoxl.Text = "课程 名 \t 最 高 分 \r\n"; 
foreach (var x in mydata) 
TextBoxl. Text += x.fl + "\t" + x.f2.ToString() + "\r\n"; 
二 
protected void Button2_Click(object sender, EventArgs e) 
{ varmydata = from Score sc in arrList2 
group sc by sc. 课程 名 into fs 
select new 
{ fl = fs. Key, 
f2 = fs.Average(sc => sc. 分 数 ) 
}; 
TextBoxl. Text =“" 课 程 名 \t 平 均 分 \r\n"; 
foreach (var x in mydata) 
TextBoxl.Text += x.fl + "\t" + x.f2.ToString() + "\r\n"; 
} 


9. 简 述 LINQ 查询 表达 式 中 from、select、where 子 句 的 作用 。 

10. LINQ to XML 包含 的 最 重要 的 3 个 类 是 什么 ? 

11. LINQ to DataSet 中 O/R 映射 器 的 作用 是 什么 ? 

12. 在 LINQ to SQL 中 插入 数据 ,更 新 数据 和 删除 数据 都 使 用 SubmitChanges 方法 ,该 
方法 的 功能 是 什么 ? 


402 
P.NET 4.5 动态 网 站 设计 教程 一 一 基于 C# 5. 0 十 SQL Server 2012 


13. 简 述 LINQ to Entities 中 ADO.NET 实体 框架 的 作用 。 

14. 在 LINQ to Entities 中 插入 数据 .更 新 数据 和 删除 数据 都 使 用 SaveChanges 方法 ,该 
方法 的 功能 是 什么 ? 

15. LINQ to Entities 和 LING to SQL 相 比 有 什么 先进 性 ? 


上 机 实验 题 13 


在 ch13-1 网 站 中 添加 一 个 名 称 为 Experment13 的 网 页 ,利用 13.6 节 创 建 的 ADO.NET 
实体 框架 ,采用 LINQ to Entities 在 GridViewl 控件 (套用 格式 为 简明 型 ,字体 为 仿宋 ) 中 显示 
Stud 数据 库 中 所 有 学 生 的 学 号 .姓名 、 班 号 .课程 名 和 分 数 ,并 按 学 号 递增 .相同 学 号 按 分 数 递 
减 排序 ,如 图 13. 32 所 示 。 


全 hapy/localhost6o42 PD - O 


x 


学 号 姓名 班 叶 课程 名 分 数 
王 华 09001 数据 结构 87 
王 华 09001 C 语 言 。 80 
对 丽 09002 C 语 言 。 70 


和 孙 丽 09002 数据 结构 52 
李兵 09001 C 语 言 ”89 
李兵 09001 数据 结构 84 
张 军 09001 数据 结构 95 
张 军 09001 (语言 。” 90 
马 柑 09002 C 语 言 ”88 
马 模 09002 数据 结构 86 


图 13. 32 上 机 实验 题 13 网 页 的 运行 界面 


Web 系统 的 多 层 结构 第 14 章 


ASP. NET 开发 的 Web 系统 是 基于 B/S 模式 的 , Web 系统 通常 是 多 层 架 
构 。 本 章 介 绍 三 层 结构 的 概念 和 实现 方法 。 

本 章 学 习 要 点 : 

回 掌握 Web 系统 多 层 结构 的 基本 概念 。 

回 掌 握 多 层 Web 系统 的 设计 方法 。 


14.1 Web 系统 的 三 层 结构 


14.1.1 什么 是 Web 系统 的 三 层 结 构 


传统 的 应 用 系统 通常 属于 两 层 应 用 系统 ,也 就 是 客户 机 /服务 器 模式 
(C/S) ,这 种 模式 只 是 两 层 架 构 ,客户 机 发 出 请 求 给 服务 器 ,服务 器 将 处 理 大 量 
来 自 客户 端的 请 求 , 经 过 业务 逻辑 运算 和 处 理 后 再 返回 给 客户 端 。 两 层 架构 的 
模式 显然 不 能 满足 现代 以 互联 网 为 趋势 的 企业 计算 处 理 要 求 ,因为 其 部 署 、 负 
载 均 衡 等 处 理 十 分 麻烦 ,所 以 就 有 了 三 层 架 构 乃 至 于 多 层 架 构 出 现 了 。 

多 层 架 构 的 核心 思想 是 将 整个 业务 应 用 划分 为 表示 层 一 业务 层 一 数据 访 
问 层 一 数据 库 , 明 确 地 将 客户 端的 表示 层 、 业 务 逻 辑 访问 、 数 据 访问 及 数据 库 划 
分 出 来 ,如 图 14. 1 所 示 。 

其 中 ,表示 层 负责 直接 跟 用 户 进行 交互 ,一 般 
指 应 用 程序 的 界面 ,用 于 数据 录入 、 数 据 显示 等 。 

业务 逻辑 层 用 于 做 一 些 有 效 性 验证 的 工作 ， 
以 更 好 地 保证 程序 运行 的 健壮 性 ,如 完成 数据 添 
加 、 修 改 和 查询 业务 等 ; 不 允许 在 指定 的 文本 框 中 
输入 空 字符 串 , 数 据 格式 是 否 正确 及 数据 类 型 验 
证 ; 用 户 的 权限 的 合法 性 判断 等 ,通过 以 上 的 诸多 
判断 来 决定 是 否 将 操作 继续 向 后 传递 ,尽量 保证 
程序 的 正常 运行 。 图 14.1 Web 系统 的 三 层 

数据 访问 层 用 于 专门 跟 数据 库 进 行 交 互 , 执 体系 结构 


用 户 表示 层 (UD) 


业务 逻辑 层 (BBL) 


数据 访问 层 (DAL) 
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行 数据 的 添加 \ 删 除 、 修 改 和 显示 等 。 需 要 强调 的 是 ,所 有 的 数据 对 象 只 在 这 一 层 被 引用 ,如 
System. Data. SqlClient 等 ,在 除数 据 层 之 外 的 任何 地 方 都 不 应 该 出 现 这样 的 引用 。 

这 样 分 层 有 利于 系统 的 开发 .维护 、 部 署 和 扩展 。 采 用 "分 而 治之 ”的 思想 把 问题 划分 开 来 
分 别 解决 ,易于 控制 、 易 于 延展 .易于 分 配 资 源 。 
14.1.2 Web 系统 三 层 结构 示例 


下 面 通过 一 个 典型 的 例子 说 明 如 何 使 用 ASP.NET 和 SQL Server 来 构建 一 个 三 层 Web 


应 用 。 
【 例 14.1】 设计 一 个 用 于 显示 指定 班 的 所 有 课程 平均 分 的 网 页 WebForml 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012 。 

@ 选择 "文件 | 新 建 | 网 站 ”命令 ,出 现 * 新 建 网 站 "对话 框 , 然 后 选择 "ASP.NET 空 网 站 ” 
模板 ,选择 "Web 位 置 " 为 “文件 系统 ”, 单 击 " 浏 览 ” 按 钮 ,选择 “D:\ASP.NET\ch14” 目 录 , 单 击 
“确定 ”按钮 ,创建 一 个 空 的 网 站 ch14。 在 Web. config 文件 的 二 configuration 记 节 插 入 以 下 连 
接 字 符 串 : 


<connectionStrings > 
<add name = "myconnstring" 
connectionString = "Data Source= LCB— PC\SQLEXPRESS; Initial Catalog = Stud; 
User ID= sa;Password = 12345" 
providerName = "System. Data. SqlClient" /> 
</connectionStrings > 


@ 系统 整体 结构 设计 。 采 用 Web 三 层 体 系 结 


用 户 表 示 层 (实现 WebForml.aspx 网 页 ) 


构 , 用 户 表示 层 对 应 WebForml 网 页 ,业务 逻辑 层 设 业务 逻辑 层 (实现 DbOp 类 ) 
计 成 DbOp 类 ,数据 访问 层 设 计 成 Database 类 ,如 
图 14. 2 所 示 。 数据 访问 层 (实现 Database 类) 


@ 数据 访问 层 DAL 设计 。 在 chl4 网 站 添加 一 


a 
个 代码 隐藏 页 模型 的 WebForml 空 网 页 ,然后 选择 
“网 站 | 添加 新 项 ”命令 ,在 弹出 的 对 话 框 中 选中 “类 ” 


选项 ,建立 的 类 文件 为 DAL. cs( 放 在 App_Code 目录 图 14.2 示例 系统 的 三 层 体系 结构 
中 ), 对 应 的 代码 如 下 : 


using System. Data. SqlClient; 
using System. Data; 
public class Database 
{ protected SqlConnection myconn; // 保 护 的 类 字段 
public Database() // 构 造 函 数 
{ string mystr = System. Configuration. ConfigurationManager. 
ConnectionStrings[ "myconnstring" ].ToString(); 
myconn = new SqlConnection(); 
myconn. ConnectionString = mystr; 
myconn. Open(); 


} 
~Database( ) // 析 构 函 数 
{ if (myconn != null) 

myconn. Close(); 
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public DataSet GetDataset(string mysql) // 返 回 数据 集 
{ DataSet myds = new DataSet(); 
SqlDataAdapter myda = new SqlDataAdapter(mysql, myconn); 
myda. Fill(myds); 


return myds; 
} 
其 中 包含 一 个 Database 类 ,通过 构造 函数 建立 并 打开 连接 ,通过 析 构 函数 关闭 连接 ,通过 
GetDataset 公有 方法 执行 指定 的 mysql 语句 并 返回 对 应 的 数据 集 。 
@ 业务 逻辑 层 BLL 设计 。 选 择 “ 网 站 ”中 的 “添加 新 项 ”命令 ,在 弹出 的 对 话 框 中 选中 
“类 ”选项 ,建立 的 类 文件 为 BLL. cs( 放 在 App_Code 目录 中 ), 对 应 的 代码 如 下 : 


using System. Data; 
public class DbOP 


{ private string bh; // 班 号 
private string retstr; // 查 找 结果 字符 串 
public string pbh // 班 号 属性 


set { bh = value; } 
: 


public string pretstr // 查 找 结果 字符 串 属性 
{ 
get { return retstr; } 
} 
public void Compute( ) // 计 算 指定 班 的 所 有 课程 的 平均 分 


{ inti= 0; 
Database db = new Database(); 
string mysql = "SELECT 课程 名 ,avg( 分 数 ) FROM student, score "; 
mysql += "WHERE student. 学 号 = score. 学 号 RND student. 班 号 ='"" + 
bh. Trim() + "'group by score. 课程 名 "; 
DataSet myds = db.GetDataset(mysql); 
if (myds. Tables[0]. Rows. Count > 0) // 存 在 该 班 的 分 数 记 录 时 
{ ”retstr = "课程 名 \t\t 平 均 分 \n"; 
while (i < myds. Tables[0].Rows. Count) 
{ retstr+= myds.Tables[0].Rows[i][0]; 
retstr += string. Format("{0:n}",myds. Tables[0]. Rows[i][1])+"\n"; 
法 夫 负 家 
} 
} 
else retstr = "没有 该 班 号 的 成 绩 "; 


} 


其 中 包含 一 个 DbOp 类 ,其 功能 是 获取 班 号 ,由 班 号 构成 一 个 SQL 语句 ,调用 Datyabase 
类 中 的 GetDataset 方法 产生 数据 集 ,将 该 数据 集中 的 所 有 记录 组 合成 一 个 结果 字符 串 并 返 
回 。 为 此 设计 bh( 班 号 ) 和 retstr( 结 果 字 符 串 ) 两 个 私有 字段 ,并 设计 与 之 对 应 的 属性 pbh 和 
pretstr, 最 后 设计 一 个 求 返 回 结果 字符 串 的 公共 方法 Compute。 

@ 用 户 表示 层 UI。 这 主要 是 设计 WebForml 网 页 ,其 设计 界面 如 图 14. 3 所 示 , 其 中 包 
含 两 个 HTML 标签 、 两 个 文本 框 (TextBoxl 为 单行 文本 框 ,TextBox2 为 多 行文 本 框 ) 和 一 个 
命令 按钮 Buttonl ,并 设计 如 下 事件 过 程 : 


protected void Buttonl Click(object sender, EventArgs e) 
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{ DbOP mydbop = new DbOP(); 
mydbop. pbh = TextBoxl. Text; 
mydbop. Compute( ); 
TextBox2. Text = mydbop.pretstr; 
} 
该 事件 过 程 将 用 户 输入 的 班 号 赋 给 mydbop 对 象 的 pbh 属性 ,然后 调用 mydbop 对 象 的 
Compute 方法 产生 查询 结果 字符 串 , 并 将 其 在 TextBox2 文本 框 中 显示 出 来 。 
至 此 ,这 种 三 层 结构 的 Web 系统 示例 设计 完毕 。 
@ 单 击 工具 栏 中 的 上 Imternet Explorer 按钮 运行 本 网 页 ,输入 09002 班 号 , 单 击 “ 计 算 平 均 分 ” 
命令 按钮 ,其 运行 结果 如 图 14.4 所 示 。 


eo 一 一 一 个 图 1@ epocahostso p- oc| OO 
班 号 : 感 localhost x 
计算 平均 分 村 号 : [6000 
pe 加 计算 平均 分 
FE 平均 分 
by c 79.00 A 
~ 结果 。 | 数据 结构 e900 ~ 
4 » 
设计 | 日 拆 分 |。 源 [J[ehtme> <body> 加 
图 14.3 WebForml 网 页 设计 界面 图 14.4 WebForml 网 页 运行 界面 


说 明 : 就 本 例 功 能 而 言 有 多 种 设计 方法 ,这 里 是 为 了 说 明 三 层 体 系 结构 而 采用 的 一 种 设 
计 方 法 ,读者 可 以 从 中 体会 Web 系统 多 层 体系 结构 的 概念 。 


14.2 ObjectDataSource 控件 


14.2.1 ObjectDataSource 控件 和 SqlDataSource 控件 的 区 别 


SqlDataSource 等 控件 极 大 地 简化 了 数据 库 的 访问 ,无 须 编写 代码 就 可 以 选择 .更 新 .插入 
和 删除 数据 库 数据 ,对 于 开发 两 层 体系 结构 (只 包含 表示 层 和 数据 访问 层 ) 的 应 用 程序 非常 容 
易 , 也 适合 于 规模 较 小 的 应 用 程序 ,但 对 于 开发 企业 级 多 层 体 系 结构 的 应 用 程序 就 效果 不 佳 ， 
因为 这 些 数据 源 控件 的 灵活 性 欠缺 ,它们 将 表示 层 和 业 表示 层 数据 绑 定 控件 
务 逻辑 层 混 合 在 一 起 。 
ObjectDataSource 控件 解决 了 这 一 问题 , 它 帮助 开 ObjectDataSource 


发 人 员 在 表示 层 与 数据 访问 层 、. 表 示 层 与 业务 逻辑 层 之 
间 建 立 联系 ,从 而 将 来 自 数 据 访问 层 或 业务 逻辑 层 的 数 | 
据 对 象 与 表示 层 中 的 数据 绑 定 控件 绑 定 ,实现 数据 的 选 

择 ,更 新 或 排序 等。 所 | 


ObjectDataSource 控件 可 以 从 . aspx 网 页 和 表示 层 中 
抽象 出 特定 的 数据 库 设置 ,并 将 它们 移 至 多 层 体系 结构 中 数据 源 数据 库 
的 较 低层 ,如 图 14. 5 所 示 。 其 中 ,ObjectDataSource 控件 


通过 接口 对 象 或 业务 实体 对 象 将 数据 传递 给 数据 做 定 图 1 利用 OeeDereSouree 控件 
控件 ,从 而 实现 各 项 功能 。 | 
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SqlDataSource 控件 中 的 ConnectionString、ProviderName 和 SelectCommand 属性 在 
ObjectDataSource 控件 中 不 存在 ,相反 .它们 被 替换 成 告诉 ObjectDataSource 控件 实例 化 哪个 
业务 类 以 及 使 用 哪个 方法 来 查询 或 修改 数据 的 其 他 属性 ,这 些 业务 类 和 方法 位 于 数据 访问 层 
或 业务 逻辑 层 中 。 


14.2.2 ObjectDataSource 控件 的 使 用 方法 


ObjectDataSource 控件 包含 的 属性 与 AccessDataSource 控件 的 类 似 , 但 增加 了 若干 用 于 
个 性 化 的 属性 。 

若 要 从 业务 对 象 中 检索 数据 , 需 用 检索 数据 的 方法 的 名 称 设置 SelectMethod 属性 ,该 方 
法 通常 返回 一 个 DataSet 对 象 。 如 果 方 法 签名 带 参 数 , 可 以 将 Parameter 对 象 添加 到 
SelectParameters 集合 ,然后 将 它们 绑 定 到 要 传递 给 由 SelectMethod 方法 指定 的 方法 的 值 。 
为 使 ObjectDataSource 能 够 使 用 参数 ,这 些 参数 必须 与 方法 签名 中 的 参数 名 称 和 类 型 相 匹 
配 。 每 次 调用 Select 方法 时 , ObjectDataSource 控件 都 检索 数据 此 方法 提供 对 
SelectMethod 属性 所 指定 的 方法 的 编程 访问 。 当 调用 绑 定 到 ObjectDataSource 的 控件 的 
DataBind 方法 时 ,这 些 控件 自动 调用 SelectMethod 属性 指定 的 方法 。 如 果 设 置 数据 绑 定 控件 
的 DataSourceID 属性 ,该 控件 根据 需要 自动 绑 定 到 数据 源 中 的 数据 。 建议 通过 设置 
DataSourceID 属性 将 ObjectDataSource 控件 绑 定 到 数据 绑 定 控 件 。 或 者 可 以 设置 
DataSource 属性 ,但 之 后 必须 显 式 调用 数据 绑 定 控件 的 DataBind 方法 。 用 户 可 以 随时 以 编程 
方式 调用 Select 方法 以 检索 数据 。 

根据 ObjectDataSource 控件 使 用 的 业务 对 象 的 功能 可 以 执行 数据 操作 ,如 更 新 .插入 和 
删除 。 若 要 执行 这 些 数据 操作 , 须 为 要 执行 的 操作 设置 适当 的 方法 名 称 和 任何 关联 的 参数 。 
例如 对 于 更 新 操作 ,将 UpdateMethod 属性 设置 为 业务 对 象 方法 的 名 称 ,该 方法 执行 更 新 并 将 
所 需 的 任何 参数 添加 到 UpdateParameters 集合 中 。 如 果 ObjectDataSource 控件 与 数据 绑 定 
控件 相关 联 , 则 由 数据 绑 定 控件 添加 参数 。 在 这 种 情况 下 ,需要 确保 方法 的 参数 名 称 与 数据 绑 
定 控件 中 的 字段 名 称 相 匹配 。 在 调用 Update 方法 时 ,由 代码 显 式 执行 更 新 或 由 数据 绑 定 控 
件 自动 执行 更 新 。Delete 和 Insert 操作 遵循 相同 的 常规 模式 。 假 定 业 务 对 象 以 逐个 记录 (而 
不 是 以 批 处 理 ) 的 方式 执行 这 些 类 型 的 数据 操作 。 

由 SelectMethod UpdateMethod .InsertMethod 和 DeleteMethod 属性 标识 的 方法 可 以 是 
实例 方法 或 static 方法 。 如 果 方 法 为 static, 则 不 创建 业务 对 象 的 实例 , 也 不 引发 
ObjectCreating、ObjectCreated 和 ObjectDisposing 事件 。 

如 果 数 据 作为 DataSet、DataView 或 DataTable 对 象 返回 ,ObjectDataSource 控件 可 以 筛 
选 由 SelectMethod 属性 检索 的 数据 。 用 户 可 以 使 用 格式 字符 串 语法 将 FilterExpression 属性 
设置 为 筛选 表达 式 , 并 将 表达 式 中 的 值 绑 定 到 FilterParameters 集合 中 指定 的 参数 。 


14.2.3 使 用 ObjectDataSource 控件 关联 数据 访问 层 和 表示 层 


数据 访问 层 主要 封装 了 对 数据 的 存储 .访问 和 管理 ,反映 到 组 件 类 中 就 体现 了 对 数据 库 执 
行 以 下 任务 的 方法 : 

。 读 取 数 据 库 中 的 数据 记录 ,并 将 结果 集 返 回 给 调用 者 。 

。 在 数据 库 中 修改 .删除 和 新 增 数据 记录 。 

在 实现 以 上 方法 的 过 程 中 必然 涉及 SELECT UPDATE、DELETE 和 INSERT 等 SQL 
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语句 ,所 涉及 的 数据 表 可 能 是 单个 表 也 可 能 是 一 组 相关 表 。 
14.2.4 ObjectDataSource 控件 应 用 示例 


下 面 通 过 一 个 示例 说 明 使 用 ObjectDataSource 控件 设计 多 层 Web 应 用 系统 的 过 程 。 

【 例 14.2】 采用 ObjectDataSource 控件 设计 一 个 网 页 WebForm2 ,其 功能 是 在 GridView 控 
件 中 显 式 指定 班 号 的 学 生 记 录 , 并 可 以 选择 、 更 新 和 删除 记录 , 当 删 除 一 个 学 生 记录 时 需 同时 
删除 该 生 的 所 有 成 绩 记录 。 

解 : 其 步骤 如 下 。 

@ 打开 chl4 网 站 ,添加 一 个 隐藏 文件 模型 的 WebForm2 的 空 网 页 。 

@ 选择 “网 站 | 添加 新 项 "命令 ,在 弹出 的 对 话 框 中 选中 “类 ”选项 ,建立 的 类 文件 为 
StudentDB( 放 在 App_Code 目录 中 ), 对 应 的 代码 如 下 : 


using System. Data; 
using System. Configuration; 
using System. Data. SqlClient; 
public class StudentDB 
{ public StudentDB() // 构 造 函 数 
{} 
public DataSet SelectDatal( string bh) 
{ string mystr; 
mystr = ConfigurationManager. ConnectionStrings["myconnstring"].ToString(); 
using (SqlConnection myconn = new SqlConnection()) 
{ myconn.ConnectionString = mystr; 
myconn. Open( ); 
SqlCommand mycmd = new SqlCommand(); 
mycmd. CommandText = "SELECT * FROM student WHERE 班 号 = @sbh"; 
mycmd. Connection = myconn; 
mycmd. Parameters. Add( "@ sbh", SqlDbType.VarChar, 5).Value = bh; 
using (SqlDataAdapter myda = new SqlDataAdapter()) 
{ myda.SelectCommand = mycmd; 
DataSet myds = new DataSet(); 
myda. Fill(myds, "student"); // 将 student 表 填 充 到 myds 中 
return myds; 


} 

} 

public static void UpdateData( string 学 号 ，string 姓名 ，string 性 别 ， 
string 民族 ，string 班 号 ) 

{ stringmystr, mysql; 

mystr = ConfigurationManager.ConnectionStrings["myconnstring"].ToString(); 

mysql = "UPDATE student SET 姓名 = @ 姓 名 ,性 别 = @ 性 别 ,民族 = @ 民 族 , ”+ 
" 班 号 = @ 班 号 WHERE 学 号 = @ 学 号 "; 

using (SqlConnection myconn = new SqlConnection(mystr)) 

using (SqlCommand mycmd = new SqlCommand(mysql, myconn)) 

{ mycmd.Parameters.Add("@ 姓 名 "，SqlDbType. VarChar，10). Value = 姓名 ; 
mycmd. Parameters. Add("@ 性 别 "，SqlDbType. VarChar, 2).Value = 性 别 ; 
mycmd. Parameters. Add("@ 民 族 "，SqlDbType. VarChar, 10).Value = 民族 ; 
mycmd. Parameters. Add("@ 班 号 "，SqlDbType. VarChar, 6).Value = 班 号 ; 
mycmd. Parameters. Add("@ 学 号 "，SqlDbType. VarChar, 5).Value = 学 号 ; 
myconn. Open( ); 
mycmd. ExecuteNonQuery(); 
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} 
public static void DeleteData( string 学 号 ) 
{ string mystr, mysql; 
mystr = ConfigurationManager. ConnectionStrings["myconnstring"]. ToString(); 
mysql = "DELETE FROM student WHERE 学 号 = @ 学 号 "; 
using (SqlConnection myconn = new SqlConnection(mystr)) 
using (SqlCommand mycmd = new SqlCommand(mysql, myconn)) 
{ mycmd.Parameters.Add("@ 学 号 "，SqlDbType. VarChar，5) .Value = 学 号 ; 
myconn. Open( ); 
mycmd. ExecuteNonQuery(); 
mysql = "DELETE FROM score WHERE 学 号 = @ 学 号 "; 
using (SqlCommand mycmdl = new SqlCommand(mysql, myconn)) 
{ mycmdl.Parameters. Add("@ 学 号 "，SqlDbType. VarChar，5). Value = 学 号 ; 
mycmd1. ExecuteNonQuery( ); 
} 


} 


上 述 代码 中 包含 StudentDB 类 的 SelectData 方法 , 它 返回 一 个 DataSet 对 象 。 其 中 using 
语句 用 于 定义 一 个 范围 ,将 在 此 范围 之 外 释放 一 个 或 多 个 对 象 ,如 定义 一 个 myconn 对 象 ,在 
其 范围 外 自动 释放 它 。 另 外 包含 一 个 修改 记录 的 UpdateData 方法 和 一 个 删除 记录 的 
DeleteData 方法 。 

@ 在 WebForm2 网 页 中 放置 两 个 HTML 标签 ,一 个 文本 框 TextBoxl. 一 个 命令 按钮 
Buttonl 和 一 个 GridViewl 控件 ,再 将 一 个 ObjectDataSource 控件 ObjectDataSourcel 拖 放 到 
本 网 页 中 。 

@ 建立 ObjectDataSourcel 控件 关联 数据 访问 层 。 在 “ObjectDataSource 任务 "列表 中 选 
择 “ 配 置 数据 源 ” 启 动 配 置 数据 源 ” 向 导 , 首 先 出 现 * 选 择业 务 对 象 "对 话 框 , 从 “选择 业务 对 象 ” 
下 拉 列 表 中 选择 “StudentDB” ,如 图 14.6 所 示 , 然 后 单 击 * 下 一 步 ? 按 钮 。 


(50 ,在 此 应 用 程序 的 Bin 或 App_Code 目录 中 定义 的 对 象 ). 


图 14.6 “选择 业务 对 象 " 对 话 框 
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@ 出 现 “ 定 义 数据 方法 ”对 话 框 ,默认 选择 SELECT 选项 卡 ,指定 与 SELECT 操作 关联 并 
返回 数据 业务 对 象 的 方法 为 StudentDB 类 的 SelectData 方法 。 

@ 选择 UPDATE 选项 卡 ,指定 与 UPDATE 操作 关联 并 返回 数据 业务 对 象 的 方法 为 
StudentDB 类 的 UpdateData 方法 。 

@ 选择 DELETE 选项 卡 ,指定 与 DELETE 操作 关联 并 返回 数据 业务 对 象 的 方法 为 
StudentDB 类 的 DeleteData 方法 , 单 击 “ 下 一 步 ” 按 钮 。 

出 现 “ 定 义 参数 ”对 话 框 ,为 SelectData 方法 定义 参数 ,该 方法 只 有 一 个 参数 bh, 它 的 值 
来 自 TextBoxl 文本 框 中 用 户 输入 的 文本 值 ,所 以 在 “参数 ”列表 中 选中 它 , 在 “参数 源 ” 列 表 中 
选中 “Control” ,在 "ControlID” 列 表 中 选中 “TextBoxl1”, 在 "DefaultValue” 文 本 框 中 输入 默认 
值 *09001”, 如 图 14.7 所 示 。 然 后 单 击 “ 完 成 ”按钮 返回 到 网 页 设计 界面 。 


图 14.7 “定义 参数 "对话 框 


在 网 页 的 源 视图 中 可 以 看 到 ObjectDataSourcel 控件 的 代码 如 下 : 


<asp:ObjectDataSource ID = "ObjectDataSourcel" runat = "server" 

DeleteMethod = "DeleteData" SelectMethod = "SelectData" TypeName = "StudentDB" 
UpdateMethod = "UpdateData"> 
< DeleteParameters> 

<asp:Parameter Name = "学 号 " Type = "String" /> 
</DeleteParameters> 
< SelectParameters> 

<asp:ControlParameter ControlID = "TextBox1" DefaultValue = "09001" Name = "bh" 

PropertyName = "Text" Type = "String" /> 
</SelectParameters> 
< UpdateParameters> 
<asp:Parameter Name = "学 号 " Type = "String" /> 
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<asp:Parameter Name = "姓名 " Type = "String" /> 

<asp:Parameter Name = "性 别 " Type = "String" /> 

<asp:Parameter Name = "民族 " Type = "String" /> 

<asp:Parameter Name = " 班 号 " TYpe = "String" /> 
</UpdateParameters> 

</asp:0bjectDataSource> 

其 中 ,ObjectDataSourcel 控件 的 DeleteMethod 属性 为 StudentDB 类 的 DeleteData 方法 ， 
表示 用 户 的 删除 操作 是 调用 DeleteData 方法 完成 的 ,由 过 DeleteParameters 二 元 素 指 出 以 学 
号 为 条 件 进 行 删除 。 

SelectMethod 属性 为 StudentDB 类 的 SelectData 方法 ,表示 用 户 的 选择 操作 (在 GridViewl 
控件 中 显示 满足 条 件 的 记录 ) 是 调用 SelectData 方法 完成 的 ,由 二 SelectParameters 过 元素 指 出 以 
文本 框 TextBoxl 值 (学 号 ,默认 值 为 09001) 为 条 件 进行 选择 。 

UpdateMethod 属性 为 StudentDB 类 的 UpdateData 方法 ,表示 用 户 的 编辑 操作 是 调用 
UpdateData 方法 完成 的 ,由 二 UpdateParameters 过 元 素 指 出 可 以 修改 所 有 字段 ,但 学 号 已 被 
设置 为 只 读 的 。 

@ 表示 层 向 用 户 提供 一 个 操作 界面 ,在 ObjectDataSource 控件 建立 好 后 ,下 面 的 步骤 实现 
ObjectDataSource 控件 与 表示 层 的 关联 。 首 先 向 本 网 页 中 拖 放 一 个 GridView 控件 GridViewl 。 

展开 “GridView 任务 ?列表 ,将 GridViewl 控件 的 AutoGenerateColumns 属性 置 为 False( 该 
属性 设置 十 分 重要 )。 然 后 选择 “编辑 列 " 命 令 , 在 “ 选 定 的 字段 ”列表 中 添加 5 个 BoundField 字段 
(数据 绑 定 字段 ) 。 

将 5 个 BoundField 字段 的 HeaderText 属性 和 DataField 属性 分 别 设置 为 “学 号 ”“ 姓 
名 ”“ 性 别 ”"“ 民 族 ” 和 * 班 号 ”。 这 不 同 于 以 前 的 操作 ,由 于 此 时 ObjectDataSource 控件 还 没 
有 与 GridView1 控件 绑 定 ,所 以 在 DataField 中 只 能 输入 以 后 绑 定 的 字段 名 ,并 将 “学 号 ?字段 
的 ReadOnly 属性 置 为 True( 规 定 学 号 字段 不 能 修改 ) ,如 图 14. 8 所 示 。 


BoundField 

|- 团 CheckBoxField 
是 HyperLnkField 

二 ImageField 
国 ButtonField 

由 国 CommandField 


图 14.8 “字段 "对话 框 
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为 了 GridViewl 控件 的 显示 和 编辑 界面 美观 ,下 面 设置 各 BoundField 字段 的 模板 。 这 里 
以 “学 号 ”字段 为 例 ,其 操作 如 下 : 

在 “ 选 定 的 字段 ”列表 中 单 击 “ 学 号 ”, 然 后 单 击 右 下 方 的 “将 此 字段 转换 为 TemplateField” 
链接 , 单 击 “ 确 定 ” 按 钮 返回 。 从 “GridView 任务 ”中 选择 “编辑 模板 ”命令 ,在 “显示 ”下 拉 列 表 
中 选择 “Column[L0]- 学 号 ”, 会 出 现 如 图 14. 9 所 示 的 编辑 模板 的 对 话 框 。 


FE 
[查找 | 


[BE 
Gridviewl - columnlol - 学 号 


器 拆 分 |。 漂 | [4][<html>][<body>][<formsforml> |[<div>] <asp:GridViewsGridView1> | 


图 14.9 编辑 模板 的 对 话 框 


其 中 ,ItemTemplate 部 分 的 Labell 控件 用 于 显示 学 号 数据 ,EditItemTemplate 部 分 的 
Labell 控件 用 于 编辑 学 号 数据 (因为 前 面 将 其 ReadOnly 属性 设置 为 True, 所 以 呈现 为 标签 ， 
否则 呈现 为 文本 框 ) ,将 这 两 个 标签 的 Width 设置 均 设置 为 55px。 

然后 在 “显示 ”下 拉 列 表 中 选择 其 他 项 ,进行 同样 的 设置 ,只 是 将 姓名 、 性 别 、 民 族 和 班 号 控 
件 的 Width 分 别 设置 为 80px、40px、70px 和 60px, 再 从 “GridView 任务 ”中 选择 “结束 编辑 模 
板 " 命 令 返 回 。 

在 “字段 ”对 话 框 中 添加 一 个 CommandField 字段 ,将 其 ButtonType 属性 置 为 "Button”。 

将 GridViewl 控件 的 DataSourceID 属性 设置 为 ObjectDataSourcel ,此 时 会 出 现 如 图 14. 10 
所 示 的 消息 框 , 单 击 “ 否 ”按钮 (如 果 单 击 “ 是 ”按钮 会 清除 前 面 的 设置 ) 。 


i 


图 14.10 消息 框 
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在 “GridView 任务 ”列表 中 选中 “启动 分 页 ”“ 启 动 编辑 "、“ 启 动 删除 ”和 “启动 选 定 内 容 ”。 

将 GridViewl 控件 的 PageSize 置 为 2,DatakeyNames 属性 置 为 “学 号 ”, 将 其 自动 套用 样 
式 置 为 “沙滩 和 天 空 ”, 将 Font 属性 置 为 “~medium, 加 粗 , 仿 宋 ”。 

在 网 页 的 源 视图 中 可 以 看 到 GridViewl 控件 的 代码 如 下 : 


<asp:GridView ID = "GridViewl" runat = "server" AllowPaging = "True" 
BackColor = "LightGoldenrodYellow" BorderColor = "Tan" BorderWidth = "1px" 
CellPadding = "2" ForeColor = "Black" GridLines = "None" PageSize= "2" DatakeyNames = "学 号 " 
style= "font 一 family: 仿宋 " AutoGenerateColumns = "False" Width = "540px" 
DataSourceID = "ObjectDataSourcel"> 
<AlternatingRowStyle BackColor = "PaleGoldenrod" /> 
<Columns > 
<asp:TemplateF ield HeaderText = "学 号 "> 
<EditItemTemplate> 
<asp:Label ID = "Labell" runat = "server" Text = '<% # Eval(" 学 号 ") %>' 
Width= "55px"></asp:Label > 
</EditItemTemplate> 
< ItemTemplate > 
<asp:Label ID = "Labell" runat = " server" Text = '<% 井 Bind(" 学 号 ") %>' 
Width = "55px"></asp:Label> 
</ItemTemplate > 
<“HeaderStyle HorizontalRlign = "Center" Width= "60px" /> 
< ItemStyle HorizontalAlign = "Center" /> 
</asp:TemplateField> 
<asp:TemplateField HeaderText = "姓名 "> 
<EditItemTemplate> 
<asp:TextBox ID = "TextBoxl"” runat = "server" Text = <% 井 Bind(" 姓 名 ") %>' 
Width = "80px"></asp:TextBox> 
</EditItemTemplate> 
< ItemTemplate > 
<asp:Label ID = "Label2" runat = "server" 
Text = '< 名 提 Bind(" 姓 名 ") 多 >></asp:Label> 
</ItemTemplate > 
<ControlStyle Width = "80px" /> 
< HeaderStyle Width= "80px" /> 
< ItemStyle HorizontalAlign = "Center" /> 
</asp: TemplateField> 
<asp:TemplateField HeaderText = "性 别 "> 
<EditItemTemplate> 
<asp:TextBox ID = "TextBox4" runat = "server" Text = '<% 井 Bind(" 性 别 ") %>' 
Width = "40px"></asp:TextBox > 
</EditItemTemplate> 
<ItemTemplate> 
<asp:Label ID = "Label5" runat = "server" Text = '<% # Bind(" 性 别 ") %>' 
Width = "40px"></asp:Label > 
</ItemTemplate> 
< HeaderStyle Width = "40px" /> 
< ItemStyle HorizontalAlign= "Center" /> 
</asp: TemplateField> 
<asp:TemplateField HeaderText = "民族 "> 
<EditItemTemplate> 
<asp:TextBox ID = "TextBox2" runat = "server" Text= < 划 # Bind(" 民 族 ") %>' 
Width = "70px"></asp:TextBox> 
</EditItemTemplate> 
< ItemTemplate > 
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<asp:Label ID = "Label3" runat = "server" Text = '<% 井 Bind(" 民 族 ") %>' 
Width = "70px"></asp:Label > 
</ItemTemplate > 
< HeaderStyle Width= "70px" /> 
< ItemStyle HorizontalAlign = "Center" /> 
</asp: TemplateField> 
<asp:TemplateField HeaderText = " 班 号 "> 
<EditItemTemplate > 
<asp:TextBox ID = "TextBox3" runat = "server" Text = '<% 井 Bind(" 班 号 ") %>' 
Width = "60px"></asp:TextBox> 
</EditItemTemplate> 
< ItemTemplate > 
<asp:Label ID = "Label4" runat = " server" Text = '<% 井 Bind(" 班 号 ") %>' 
Width = "60px"></asp:Label > 
</ItemTemplate> 
< HeaderStyle Width = "60px" /> 
< ItemStyle HorizontalAlign = "Center" /> 
</asp: TemplateField> 
<asp:CommandField ButtonType = "Button" ShowDeleteButton= "True" 
ShowEditButton = "True" ShowSelectButton = "True" > 
< ControlStyle ForeColor = "Red" Font- Bold = "True" Font - Names = "黑体 " /> 
</asp:CommandField > 
</Columns > 
< FooterStyle BackColor = "Tan" /> 
<HeaderStyle BackColor = "Tan" Font ~ Bold= "True" /> 
< PagerStyle BackColor = "PaleGoldenrod" ForeColor = "DarkSlateBlue" 
HorizontalAlign = "Center" /> 
< SelectedRowStyle BackColor = "DarkSlateBlue" ForeColor = "GhostWhite" /> 
< SortedAscendingCellStyle BackColor = " #FAFAE7" /> 
< SortedAscendingHeaderStyle BackColor = " #DACO9E" /> 
< SortedDescendingCellStyle BackColor = " #E1DB9C" /> 
< SortedDescendingHeaderStyle BackColor = " 间 C2A47B" /> 
</asp:GridView > 


至 此 本 网 页 设计 完成 ,其 设计 界面 如 图 14. 11 所 示 。 网 页 中 的 Buttonl 命令 按钮 上 没有 
设计 任何 事件 处 理 过 程 , 它 仅 仅 用 于 向 服务 器 提交 网 页 。 在 整个 网 页 设计 中 除了 操作 外 不 包 
含 任何 程序 代码 ,实际 上 是 将 处 理 功能 提炼 出 来 单独 放 在 StudentDB 类 中 ,从 而 将 网 页 界面 
设计 与 功能 设计 相 分 离 , 这 就 是 多 层 Web 开发 的 精髓 。 


查找 
数 磊 男 歼 据 尘 定 丈 括 数据 竺 定 数据 绑 | 芭 | - 副 际 | 这 到 | 
至 闫 绕 数据 铸 定 获 括 数据 铸 定 数 冯 钱 区 到 | 型 队 | 运 绎 | 


12 
起 


ObjectDataSource - ObjectDataSourcel 
PR | 要 
4 3 » 

5G 设计 <body> |[<formsform1>|[<div>| <asp:GridView#GridView1> 时 


图 14. 11 WebForm2 网 页 设计 界面 
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图 单 击 工具 栏 中 的 上 Internet Explorer 按钮 运行 本 网 页 ,初始 结果 如 图 14. 12 所 示 , 默 认 显示 
09001 班 的 所 有 学 生 , 在 “ 班 号 "文本 框 中 输入 “09002”, 单 击 “ 查 找 ” 命 令 按 钮 ,其 结果 如 图 14. 13 
所 示 ,这 样 将 显示 09002 班 的 所 有 学 生 记录 。 


图 14. 13 WebForm2 网 页 运行 界面 二 


用 户 可 以 进行 翻 页 操作 。 当 单 击 “编辑 ”按钮 时 ,进入 所 选 记 录 的 编辑 界面 ,图 14. 14 所 示 
的 是 学 号 为 2 的 记录 的 编辑 界面 ,此 时 用 户 可 以 修改 除了 学 号 以 外 的 其 他 字段 ,用 户 单 击 “ 更 
新 ”按钮 会 调用 UpdateData 方法 修改 student 表 , 单 击 “ 取 消 ” 按 钮 表示 放弃 修改 并 返回 。 当 


图 14.14 WebForm2 网 页 运行 界面 三 
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单 击 “ 删 除 ” 按 钮 时 调用 DeleteData 方法 ,不 仅 会 删除 student 表 中 所 选 的 记录 ,还 会 删除 
score 表 中 所 有 该 学 号 的 成 绩 记 录 ( 这 是 由 DeleteData 方法 实现 的 ) 。 

说 明 : 在 GridViewl 控件 中 单 击 “编辑 ”按钮 时 会 出 现 默认 的 记录 编辑 界面 ,可 能 和 
GridViewl 控件 中 该 记录 的 显示 格式 很 不 一 样 ,导致 界面 十 分 难看 ,前 面 的 编辑 模板 就 是 使 得 
两 种 格式 一 致 ,从 而 美化 记录 修改 界面 。 

本 例 的 功能 完全 可 以 使 用 SqlDataSource 控件 实现 ,但 使 用 ObjectDataSource 控件 时 可 
以 在 组 件 类 文件 StudentDB. cs 的 StudentDB 类 中 加 入 更 多 的 方法 以 实现 更 复杂 的 多 层 业务 
人 逻辑 功能 。 另 外 ,ObjectDataSource 控件 的 InsertCommand 属性 主要 和 DetailsView 等 控件 

合 实现 记录 的 插入 。 


练习 题 14 


1. 简 述 Web 系统 的 三 层 结构 及 其 各 层 的 主要 功能 。 
2. 简 述 为 什么 采用 多 层 Web 系统 结构 。 
3. 简 述 ObjectDataSource 控件 和 SqlDataSource 控件 的 异同 。 


上 机 实验 题 14 


在 chl4 网 站 的 StudentDB 类 文件 中 添加 两 个 方法 : 


public DataSet SelectData() 
public static void InsertData( string 学 号 ，string 姓名 ，string 性 别 ，string 民族 ，string 班 号 ) 


再 添加 一 个 名 称 为 Expermentl4 的 网 页 ,其 中 包含 一 个 GridViewl 控件 和 一 个 
DetailsViewl 控件 ,并 利用 ObjectDataSource 控件 实现 学 生 记 录 的 显示 和 输入 。 例 如 ,用 户 运 
行 该 网 页 ,首先 调用 SelectData 方法 在 GridViewl 控件 中 显示 所 有 学 生 记录 ,其 选择 学 号 3 的 
界面 如 图 14. 15 所 示 ; 用 户 单 击 “ 新 建 "按钮 便 可 以 插入 一 个 新 的 学 生 记 录 , 如 图 14. 16 所 示 ; 
在 输入 新 的 学 生 记 录 后 , 单 击 “ 插 入 ”按钮 调用 InsertData 方法 将 该 记录 插入 到 student 表 中 ， 
单 击 “取消 ”按钮 不 做 插入 。 


所 S|[@ hepy/ocalhost6009Y/Expermentl4.aspx p-cd oe 


所 有 学 生 记录 


14.15 上 机 实验 题 14 网 页 的 运行 界面 一 
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@a TD 


@ htp://localhost60091/Experment14.aspx Pd 本 
@ localhost x 加 加 


插入 单个 学 生 记 录 人 ~ 


图 14.16 上 机 实验 题 14 网 页 的 运行 界面 二 


第 15 章 ASP.NET Web 服务 


Web 服务 (Web Service) 是 一 项 新 兴 发 展 的 技术 。 它 以 “软件 就 是 服务 ”为 
理想 目标 ,使 得 在 系统 架构 以 及 软件 开发 等 领域 都 发 生 了 深刻 的 变化 。Web 服 
务 是 Microsoft 公司 的 .NET 策略 计划 的 基础 。 本 章 介 绍 了 Web 服务 的 创建 
和 调用 Web 服务 的 方法 。 

本 章 学 习 要 点 : 

加 掌握 Web 服务 的 概念 。 

回 掌 握 创 建 Web 服务 的 方法 。 

回 掌 握 Web 服务 的 调用 方法 。 

回 掌 握 引 用 Web 服务 的 方法 。 

回 掌 握 在 AJAX 内 容 页 中 引用 Web 服务 的 方法 。 


15.1 Web 服务 概述 


Web 服务 (Web Services) 是 Web 服务 器 上 的 一 些 组 件 , 客 户 端 应 用 程序 可 

通过 Web 发 出 HTTP 请 求 来 调用 这 些 服务 , 它 是 一 种 构建 新 的 Web 应 用 程序 
的 普通 模型 ,并 能 在 所 有 支持 Internet 通信 的 操作 系统 上 实施 运行 。 
一 个 Web 服务 就 是 一 个 应 用 Web 协议 的 可 编程 的 应 用 程序 逻辑 。 实 际 
上 ,Web 服务 就 是 一 个 动态 链接 库 DLL, 它 向 外 界 显示 出 的 是 一 个 能 够 通过 
Web 进行 调用 的 API。 用 户 不 需要 知道 它 的 内 部 实现 ,只 需要 知道 它 的 调用 郴 
数 名 和 参数 即 可 。 与 普通 的 DLL 不 同 的 是 , 它 不 存在 于 本 地 主机 上 ,而 是 存在 
于 服务 器 端 ,因此 Web 服务 可 以 被 任何 能 访问 本 机 的 网 络 用 户 调用 。 


15.1.1 Web 服务 的 特点 


Web 服务 具有 以 下 特点 : 

。 Web 服务 是 应 用 程序 组 件 。 

。 Web 服务 使 用 开放 协议 进行 通信 。 

。 Web 服务 是 独立 的 并 可 自我 描述 。 

。 Web 服务 可 通过 使 用 UDDI 来 发 现 。 
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。 Web 服务 可 被 其 他 应 用 程序 使 用 。 
。 XML 是 Web 服务 的 基础 。 


15.1.2 Web 服务 的 体系 结构 
Web 服务 体系 结构 如 图 15. 1 所 示 ,主要 包括 以 下 几 个 方面 。 


服务 注册 中 心 


发 布 发 现 


吕 


绑 定 


服务 提供 者 服务 请 求 者 
图 15.1 Web 服务 体系 结构 


1. Web 服务 体系 结构 的 组 件 
Web 服务 体系 结构 包括 下 面 3 种 组 件 。 
服务 提供 者 : 服务 的 拥有 者 , 它 为 其 他 用 户 或 服务 提供 服务 功能 。 服 务 提供 者 先 要 向 
服务 注册 中 心 注册 自己 的 服务 描述 和 访问 接口 (发 布 操作 )。 
服务 注册 中 心 : 把 服务 提供 者 和 服务 请 求 者 绑 定 在 一 起 ,提供 服务 发 布 和 查找 功能 。 
。 服务 请 求 者 : Web 服务 功能 的 使 用 者 , 它 先 向 服务 注册 中 心 查找 所 需要 的 服务 ,服务 
注册 中 心 根据 服务 请 求 者 的 请 求 把 相关 的 Web 服务 和 服务 请 求 者 进行 绑 定 ,这 样 服 
务 请 求 者 就 可 以 从 服务 提供 者 那儿 获取 需要 的 服务 。 
2. Web 服务 体系 结构 的 操作 
Web 服务 体系 结构 包括 下 面 3 种 操作 。 
。 发 布 : 服务 提供 者 向 服务 注册 中 心 发 布 相 关 服 务 的 注册 。 
。 发 现 : 由 服务 请 求 者 向 服务 注册 中 心 执 行 find 操作 ,服务 请 求 者 描述 要 找 的 服务 , 服 
务 注册 中 心 分 发 匹配 的 结果 。 
。 绑 定 : 在 服务 请 求 者 和 服务 提供 者 之 间 绑 定 , 这 两 部 分 协商 以 使 服务 请 求 者 可 以 访问 
和 调用 服务 提供 者 的 服务 。 
3. UDDI 一 一 通用 查找 ,描述 和 集成 协议 
这 是 一 个 Web 服务 的 信息 注册 规范 .定义 了 Web 服务 的 注册 发 布 和 发 现 的 方法 。UDDI 
类 似 一 个 目录 索引 , 列 出 了 所 有 可 用 的 Web 服务 信息 。 服 务 请 求 者 可 以 在 这 个 目录 中 找到 自 
己 需 要 的 服务 。 
4. WSDL 一 一 Web 服务 描述 语言 
Web 服务 描述 言语 言 (WSDL) 是 一 种 基于 XML 语法 的 为 服务 提供 者 提供 了 描述 构建 在 
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不 同 协议 或 编码 方式 之 上 的 Web 服务 请 求 基本 格式 的 语言 。WSDL 用 来 描述 一 个 Web 服务 
能 做 什么 , 它 的 位 置 在 哪里 ,如 何 调用 它 等 。 
UDDI 描述 了 Web 服务 的 绝 大 多 数 方面 ,包括 服务 的 绑 定 细节 。WSDL 可 以 被 看 作 是 
UDDI 服务 描述 的 子 集 。 
一 个 WSDL 文档 在 定义 网 络 服务 的 时 候 使 用 以 下 元 素 。 
。 definitions( 定 义 ): 所 有 WSDL 文档 的 根 元 素 , 定 义 Web 服务 的 名 称 , 声 明文 档 其 他 
部 分 使 用 的 命名 空间 ,并 包含 这 里 描述 的 所 有 服务 元 素 。 
。 types( 类 型 ) : 描述 在 客户 端 和 服务 器 之 间 使 用 的 所 有 数据 类 型 。 
message( 消 息 ) : 描述 一 个 单 向 消息 ,包括 请 求 消息 和 响应 消息 。 
。 portType( 端 口 类 型 ) : 结合 多 个 message 元 素 , 形 成 一 个 完整 的 单 向 或 往返 操作 。 一 
个 portType 可 以 定义 多 个 操作 。 
。 binding( 绑 定 ): 描述 了 在 Internet 上 实现 服务 的 具体 细节 。 
service( 服 务 ) : 定义 了 调用 服务 的 地 址 。 


15.2 创建 和 使 用 Web 服务 


15.2.1 创建 ASP.NET Web 服务 网 站 


Web 服务 是 提供 给 请 求 者 使 用 的 ,通常 创建 一 个 能 从 外 部 访问 的 Web 服务 网 站 ,本 节 采 
用 外 部 IIS( 而 不 是 Visual Studio 内 置 的 IIS Express) 创 建 一 个 Web 服务 网 站 MyWeb。 其 步 
又 如 下 ， 

J@ 在 计算 机 上 安装 IIS 7.0 或 更 高 版 本 (这 里 采用 IIS 7.0) ,在 “D:\ASP.NET" 目 录 中 创 
建 一 个 MyWeb 子 目录 。 


说 明 : 在 Windows 中 选择 “控制 面板 | 程序 i 
和 功能 | 打开 或 关闭 Windows 沪 能 个人 六 各 兴 el Wo © 
看 到 如 图 15. 2 所 示 的 Internet 信息 服务 ,表示 || gqyyf_poplg ,aRNODENE 才 要 x 二 _4th 榴 ,调和 
安装 正确 。 Ps es 

@ 在 Windows 中 选择 “控制 面板 | 管理 工具 | 回 吕 rrr 11 


Internet 信息 服务 (IIS) 管理 器 "命令 ,出 现 四 me me we 


“Internet 信息 服务 (IIS) 管 理 器 ?对话 框 ,展开 右 时 一 


侧 的 服务 器 , 右 击 “网 站 ”, 在 出 现 的 快捷 菜单 中 田 团 朋 万 准 网 服务 = 


选择 “添加 网 站 ”命令 。 本 
@ 出 现 “ 添 加 网 站 ”对 话 框 ,输入 网 站 名 称 
为 “Web”, 选择 物理 路 径 为 “D:\ASP. NET\ 图 15.2 “Windows 功能 ”对 话 框 


MyWeb”, 如 图 15. 3 所 示 . 单 击 “ 确 定 ” 按 钮 返回 。 
@ Web 服务 网 站 必须 启用 目录 浏览 功能 ,为 此 选择 "功能 视图 ”选项 卡 ,双击 其 中 的 “目录 
浏览 ”选项 ,在 目录 浏览 页 面 的 “操作 ” 窗 格 中 单 击 “ 启 用 ”, 如 图 15. 4 所 示 , 返 回 到 Windows。 
@@ 启动 Visual Studio 2012。 
@ 选择 “文件 | 新 建 | 网 站 "命令, 出现“ 新 建 网 站 ”对 话 框 ,然后 选择 ?ASP.NET 空 网 站 ” 
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图 15.3 “添加 网 站 ”对 话 框 


文件 (F) 。 视 问 V) 帮助 (H) 
一 @ Web 主页 
2 ee (LCB-PCVAdministrator) KE - 次 开始 (G) - 同 全 本 时 A) | 分 相信 大: 
4 国 网 站 Asp CGI HTTP 响应 标 HTTP 重 定 向 Ip 地 址 和 域 | 
人 头 Ee 
入 产品 色 末 
1SAPI 答 运 各 MIME 类 型 。 SSL 设 辕 ”WebDAV 创 处 理 程序 耽 
人 规则 对 
加 诈 18 号 莘 
错 模块。 吕 M 六 站 请 求 入 和 
上 友 昆 名 及 
日 去。 身份 验证 失 清 未 梁 。 授权 规则 。 给 出 拓 存 
规则 
图 3 
ES 内容 视图 
Lj] 


图 15.4 在 目录 浏览 页 面 中 单 击 * 启 用 ”后 的 界面 


模板 ,选择 ”Web 位 置 " 为 “HTTP”, 单 击 “ 浏 览 ” 按 钮 , 出现“ 选择 位 置 ” 对 话 框 , 单 击 “ 本 地 
IIS” ,选择 “Web”, 如 图 15. 5 所 示 , 单 击 “ 打 开 ” 按 钮 ,创建 一 个 空 的 网 站 Web。 
说 明 : 这 里 创建 的 Web 服务 网 站 的 名 称 为 Web、URL 为 “http://localhost/”、 完 整 路 径 


为 “D:\ASP.NET\MyWeb”。 
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图 15.5 “选择 位 置 "对 话 杠 


15.2.2 创建 ASP.NET Web 服务 


下 面 通过 一 个 示例 说 明 创 建 ASP.NET Web 服务 的 过 程 。 

【 例 15. 1】 在 前 面 建 好 的 Web 网 站 中 创建 一 个 Web 服务 。 

解 : 其 步骤 如 下 。 

@ 启动 Visual Studio 2012 ,打开 Web 网 站 。 

@ 选择 "网 站 | 添加 新 项 命令, 出现“ 添加 新 项 -http://localhost/ ”对话 框 ,在 中 间 列 表 中 
选择 "Web 服务 ”模板 ,保持 默认 的 WebService. asmx 文件 名 ,如 图 15.6 所 示 , 单 击 “ 添 加 ” 按 
钮 。 网 站 中 出 现 了 一 个 WebService. asmx 文件 ,其 代码 文件 WebService. cs 被 放 在 自动 创建 
的 App_Code 目录 中 。 

@@ WebService. asmx 文件 包含 以 下 代码 : 


< 外 @ WebService Language = "C#" CodeBehind = "~ /App_Code/WebService. cs" 
Class = "WebService” %> 


其 中 WebService 指令 指定 相关 属性 设置 ,属性 与 Page 指令 的 属性 类 似 。 
WebService. cs 文件 的 初始 代码 如 下 : 


using System; 
using System; 
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using System. Collections. Generic; 
using System. Ling; 
using System. Web; 
using System. Web. Services; 
/// < summary> 
/// WebService 的 摘要 说 明 
/// </ summary> 
[WebService(Namespace = "http://tempuri. org/")] 
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfilel 1)] 
// 车 允许 使 用 RSP .NET AJAX 从 脚本 中 调用 此 Web 服务 ,请 取消 注释 以 下 行 
// [System. Web. Script.Services. ScriptService] 
public class WebService : System. Web. Services. WebService { 
public WebService () { 
// 如 果 使 用 设计 的 组 件 , 请 取消 注释 以 下 行 
//InitializeComponent(); 
} 
[WebMethod] 
public string HelloWorld() { 
return "Hello World"; 
} 
} 


上 述 代 码 声 明了 一 个 WebService 类 ,从 System. Web. Services. WebService 类 派生 ,默认 
的 命名 空间 为 “http://tempuri, org/”, 并 自动 生成 了 一 个 Web 服务 方法 HelloWorld。 


搜索 已 安装 模板 (Ctrl+ 日 
类 型 :Visual C# 
用 于 创建 Web 服务 的 可 视 设计 类 


2 


图 15.6 “添加 新 项 -http://localhost/ "对 话 框 


注意 : 只 要 是 Web 服务 提供 的 方法 ,在 方法 定义 的 上 面 都 需要 添加 [WebMethod] 特 性 进 
行 声 明 , 表 示 该 方法 可 以 由 Web 调用 。 

@ 单 击 工具 栏 中 的 Internet Explorer 按钮 运行 WebService. cs 文件 ,出 现 如 图 15.7 所 示 的 
运行 界面 , 单 击 HelloWorld 超 链接 ,出 现 如 图 15. 8 所 示 的 运行 界面 , 单 击 “ 调 用 ”命令 按钮 ,出 
现 如 图 15. 9 所 示 的 运行 界面 ,表示 调用 HelloWorld 服务 的 结果 是 返回 ”Hello World”, 这 里 
是 采用 XML 文档 的 形式 返回 结果 的 。 
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DC 也 证 三 2 


此 Web 服务 使 用 http://tempuri.org/ 作为 鞭 认 命名 空间 。 
建议 : 公开 XML Web services 之 前 ， 请 于 次 点 认命 名 空间 。 
二 


5.0 十 SQL Server 2012 


全 感 htpy/localhostyWebsemvice:P -上 | 人 0 
铭 webservice Web 匡 务 


| 
单 二 此 外， 获取 殉 整 的 刚 作 列表 - 


HelloWorld 
到 二 


Fm HTTP POST 荔 议 对 操作 进行 测试 。 请 间 击 "调用 " 核 钥 - 


SOAP 1.1 
< 


图 15.7 Web 服务 界面 


( E 居 http//localhost/WebService.asmx/HelloWorld 


| 土 localhos "i 


<?xml version="1.0" encoding="UTF-8"?> 
<string xmIns="http:/ /tempuri.org/">Hello World</string> 


图 15.9 ”HelloWorld 服务 运行 结果 


本 例 创 建 的 ch15 网 站 是 一 个 Web 服务 网 站 ,其 URL 为 “http://localhost:51067”。 下 


面 介绍 一 个 自 定义 Web 服务 的 设计 过 程 。 


【 例 15.2】 在 例 15. 1 创建 的 Web 服务 中 添加 一 个 实现 两 个 整数 相 加 的 服务 。 


解 : 其 步骤 如 下 。 
OOD 打开 Web 网 站 的 WebService. cs 文件 。 
@ 在 Service 类 中 添加 如 下 代码 : 


[WebMethod] 
public int add(int a, int b) 
{ 
returna + b; 
} 
其 中 ,Web 方法 的 设计 与 普通 类 的 方法 设 


计 相 同 。 

@ 单 击 工 具 栏 中 的 p> InternetExplorer 按钮 
运行 WebService. cs 文件 ,出 现 如 图 15. 10 所 
示 的 运行 界面 ,其 中 包含 了 add 服务 , 单 击 add 
超 链 接 , 出 现 如 图 15. 11 所 示 的 add 服务 运行 
界面 ,在 参数 文本 框 中 分 别 输入 2 和 6， je 
“调用 ”命令 按钮 ,出 现 如 图 15. 12 所 示 的 运 
界面 ,表示 本 次 调用 add 服务 的 结果 是 8。 

从 中 可 以 看 到 ,调用 一 个 Web 服务 就 是 
调用 Web 服务 的 一 个 Web 方法 ,其 返回 结果 


(© 四 http//localhost/WebSevice, P © 
愿 webservice Web 服务 


WebService 


支持 下 列 冯 作 .有 关 正式 定义 二 查 乔 服务 民明 . 


。 HelloWorld 


”add 


= Web 服务 使 用 http:/ /tempuriorg/ 作为 默认 命名 空 vy 


这 > 


图 15.10 Web 服务 界面 
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是 采用 XML 表示 的 。 


单 击 此 处 ， 获 取 充 整 的 护 作 列表 


add 


测试 
着 要 信用 HTTP POST 雪 议 对 强人 进行 测 芝 二 音 击 "请 同村 色 - 
[i 后 图 |@@ tipocalhosWebseicea: DO 


a: [2 感 localhost x 

b: 加 x 
<?xml version="1.0" encoding="UTE-8*?> 
<int sno http /tempur orgl > 9 int> 


图 15.11 add 服务 运行 界面 图 15.12 add 服务 运行 结果 


15.2.3 使 用 ASP .NET Web 服务 


Web 服务 的 主要 作用 就 是 供 客户 端 程序 调用 。 在 访问 Web 服务 时 ,. NET 框架 等 完成 了 
大 部 分 工作 ,用 户 只 需要 在 代码 中 调用 代理 类 的 相应 方法 即 可 。 下 面 通过 示例 说 明 使 用 Web 
服务 的 过 程 。 

【 例 15.3】 创建 一 个 应 用 网 站 ch15 ,设计 一 个 使 用 add 服务 网 页 的 WebForml 网 页 。 

解 : 其 步骤 如 下 。 

Q@ 创建 一 个 以 “D:\ASP.NET\ch15” 为 路 径 的 空 网 站 ,添加 一 个 代码 隐藏 页 模型 的 
WebForml 空 网 页 。 

@ 右 击 ch15 项 目 名 ,在 出 现 的 快捷 菜单 中 选择 “添加 服务 引用 ”命令 ,打开 “添加 服务 引 
用 ”对 话 框 ,如 图 15. 13 所 示 。 


车 要 查看 特定 服务 器 上 的 可 用 服务 列表 ,请 内 入 服务 URL , 然后 单 击 “ 转 到 ”。 若 要 浏览 可 用 的 服务 ,请 单 
击 “发现” . 


-eed) | (ened 


图 15. 13 “添加 服务 引用 ”对 话 框 
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@ 保持 默认 的 命名 空间 ServiceReferencel, 单 击 “ 高 级 "按钮, 出现 如 图 15. 14 所 示 的 “ 服 
务 引 用 设置 ”对话 框 。 


图 15. 14 “服务 引用 设置 ”对话 框 


@ 单 击 “添加 Web 引用 ”按钮 ,出 现 “ 添 加 Web 引用 ”对 话 框 ,如 图 15. 15 所 示 , 然 后 单 击 
“本 地 计算 机 上 的 Web 服务 "链接 进行 查找 ,也 可 以 直接 在 URL 中 输入 “http://localhost/ 
WebService. asmx”, 单 击 后 面 的 “一 ”按钮 ,出 现 如 图 15. 16 所 示 的 结果 , 单 击 “ 添 加 引用 ” 
按钮 。 

@ 打开 Web. config 文件 ,看 到 其 中 自动 添加 了 以 下 代码 : 

<appSettings> 

<add key= "localhost. WebService" value = "http://localhost/WebService. asmx" /> 

</appSettings > 

这 表示 设 定 了 代理 类 localhost 所 引用 的 Web 服务 的 URL。 在 解决 方案 资源 管理 器 中 看 
到 新 建 了 一 个 App_WebReferences 目录 ,其 中 包含 localhost 类 的 子 目 录 。 

@ 设计 WebForml 网 页 如 图 15. 17 所 示 , 其 中 包含 两 个 文本 框 (TextBoxl 和 
TextBox2) ,另外 有 一 个 命令 按钮 Buttonl 和 一 个 标签 Labell。 在 该 网 页 上 设计 如 下 事件 
过 程 : 


请 定位 到 提供 Web 服务 的 URL , 然后 单 去“ 添 j05| 用 ” ， 添 加 位 于 该 URL 上 的 所 有 可 用 服务 . 


ee@lxo6 


URLU): | 


公信 Web 服务 的 起 始点 。 您 可 以 单 击 下 面 的 链接 ， 或 者 在 地 址 栏 中 
键入 已 知 的 URL。 
Web 


UDDI 


。 
在 您 的 本 地 网 络 上 查询 UDDI 服务 器 * ee 


图 15.15 “添加 Web 引用 ”对 话 框 


请 定位 到 提供 Web 服务 的 URL , 然后 单 二 “添加 引用 ” ， 添 加 位 于 该 URL 上 的 所 有 可 用 服务 . 
o@xon 


wa 


支持 下 列 歇 作 、 有 关 正式 定义 ， 请 查看 肛 务 说 明 . 
。 Helloworld 
» add 


此 Web 服务 使 用 http://tempuri.org/ 作为 战 认 命名 空间 。 
建议 : 公开 XML Web services 之 前 ， 请 更 改 默 认命 名 空间 


每 个 XML Web services 者 项 要 一 个 唯一 的 会 名 空间 ， 以 便 阁 户 坟 应 及 程序 能 够 将 它 与 
Web 上 的 其 他 服务 区 分 开 。http://tempuri.org/ 可 用 于 处 于 开发 阶 各 的 XML Web 
services， 而 已 发 布 的 XML Web services 应 使 用 更 为 永久 的 命 儿 空间. 


应 使 用 人 控制 的 会 各 空间 来 标识 XML Web services- 例 各， 可 以 使 用 公司 的 Internet 域 
冬 作为 全 各 空间 的 一 部 分 。 六 管 有 许多 XML Web services 命 入 空间 乔 似 URL， 伍 它们 不 乡 


指向 Web 上 的 实际 资源 . (XML Web services 今冬 空间 为 URI. ) 


使 用 ASP.NET 创建 XML Web services 时 .可 以 使 用 WebService 特性 的 
Namespace 属性 更 改 的 认命 名 空间 .WebService 特性 秋月 于 包含 XML Web services 
方法 的 类 。 下 画 的 代码 实例 将 命名 空间 设置 为 “http://microsoft.com/webservices/": 


ce 
[WebService (Nameapace—"http://microsoft.com/webservices - 
» 


图 15.16 查找 服务 的 结果 
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protected void Buttonl Click(object sender, EventArgs e) 
int m, n; 
m= jint.Parse(TextBoxl. Text); 
n = int.Parse(TextBox2. Text); 
localhost. Service myservice = new localhost. Service(); 
Labell. Text = "调用 结果 :" + myservice.add(m, n).ToString(); 
} 


@ 单 击 工 具 栏 中 的 Internet Explorer 按钮 运行 本 网 页 ,输入 2 和 6, 然 后 单 击 “ 相 加 ”命令 按 
钮 ,其 运行 界面 如 图 15. 18 所 示 。 


ex" 
ee ee 
pp 大 localhost 
整数 2: 
EDT 
[Label1] 
4 人 
mt |ewg |* 吾 | 图 <dv> 加 


图 15.17 WebForml 网 页 设计 界面 图 15.18 WebForml 网 页 运行 界面 


说 明 : 例 15.2 的 add 方法 调用 是 在 Web 服务 网 站 (Web) 中 运行 的 ,而 例 15. 3 是 在 另 一 
个 网 站 (ch15) 中 调用 add 方法 。 也 就 是 说 ,Web 服务 网 站 提供 了 被 其 他 网 站 调用 的 服务 。 


15.3 通过 Web 服务 传输 DataSet 数据 集 


DataSet 对 象 是 采用 断 开 式 设 计 的 ,其 部 分 目的 是 便于 Internet 传输 数据 ,可 以 将 DataSet 
指定 为 Web 服务 的 输入 或 输出 。Web 服务 和 客户 端 之 间 将 DataSet 内 容 以 流 的 形式 来 回 传 
递 。 下 面 通过 一 个 示例 进行 说 明 。 

【 例 15. 4】 在 chl5 网 站 中 设计 一 个 使 用 Web 服务 显示 student 表 记 录 的 网 页 
WebForm2。 

解 : 其 步骤 如 下 。 

@O 打开 前 面 建立 的 Web 网 站 ,然后 打开 网 站 中 的 Web. config 文件 ,在 二 configuration 二 
节 中 添加 如 下 连接 字符 串 ， 


<connectionStrings > 
<add name = "myconnstring" 
connectionString = "Data Source= LCB— PC\SQLEXPRESS; Initial Catalog = Stud; 
User ID = sa;Password= 12345" 
providerName = "System. Data. SqlClient" /> 
</connectionStrings > 


@ 选择 “网 站 | 添加 新 项 ”命令 ,出 现 “ 添 加 新 项 -http://localhost/” 对 话 框 ,在 中 间 列 表 中 
选择 “Web 服务 ”模板 ,修改 文件 名 为 “WebServicel. asmx”, 单 击 “ 添 加 ”按钮 。 然 后 打开 
WebServicel. cs 文件 ,删除 其 中 的 HelloWorld 方法 代码 ,在 引用 部 分 添加 如 下 引用 : 


using System. Data; 
using System. Data. SqlClient; 
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在 WebServicel 类 中 添加 如 下 方法 代码 : 


[WebMethod] 
public DataSet getdata() 
{ string mystr, mysql; 
mystr = System. Configuration.ConfigurationManager. 
ConnectionStrings["myconnstring"].ToString(); 
SqlConnection myconn = new SqlConnection(); 
myconn. ConnectionString = mystr; 
myconn. Open( ); 
mysql = "SELECT #* FROM student"; 
SqlDataAdapter myda = new SqlDataAdapter(mysql, myconn); 
DataSet myds = new DataSet(); 
myda. Fill(myds, "student"); // 将 student 表 填 充 到 myds 中 
myconn. Close( ); 
return myds; 
} 
在 解决 方案 资源 管理 器 中 右 击 “http://localhost/” 项 目 名 ,在 出 现 的 快捷 菜单 中 选择 “对 
网 站 运行 代码 分 析 ” 命 令 , 可 以 查看 Web 服务 代码 是 否 存 在 错误 。 
@ 采用 例 15. 3 的 操作 添加 对 “http://localhost/ WebServicel. asmx” 的 引用 , Web. 
config 文件 的 二 appSettings 二 节 自 动 改 变 为 ， 
<“appSettings > 
<add key= "localhost. WebService" value = "http://localhost/WebService. asmx"/> 
<add key = "localhost. WebServicel" value = "http://localhost/WebServicel. asmx"/> 
</appSettings > 
@ 选择 “文件 | 关闭 解决 方案 ”命令 关闭 Web 网 站 。 然 后 打开 ch15 网 站 ,添加 一 个 名 称 
为 WebForm2 的 空 网 页 。 在 网 页 中 拖 放 一 个 GridView 控件 GridView1, 设 置 其 自动 套用 格 
式 “ 沙 浴 和 天 空 ”, 不 设置 它 的 数据 源 。 在 本 网 页 上 设计 如 下 事件 过 程 ， 
protected void Page_Load( object sender, EventArgs e) 
{ localhost. WebServicel myservice = new localhost.WebServicel(); 
GridView1.DataSource = myservice.getdata(); 
GridView1.DataBind( ); 
. 


@ 单 击 工具 栏 中 的 > Internet Explorer 按钮 运行 本 网 页 ,其 运行 界面 如 图 15. 19 所 示 。 


图 |@ rsp/ocalhosts105 DP - © 


忽 localhost x ' 

学 号 姓名 性 别 民族 班 叶 
1 玉 华 女 汉族 09001 | 
区 录 面 女 。 汉族 | 
3 李兵 男 满族 09001 
6 张 军 男 汉族 09001 | 
8 马 棋 男 回族 ”09002 


图 15.19 WebForm2 网 页 运行 结果 
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15.4 在 AJAX 内 容 页 中 引用 Web 服务 


在 第 11 章 介 绍 过 ASP .NET AJAX 控件 的 使 用 。 一 个 ASPX 网 页 上 只 能 有 一 个 
ScriptManager 控件 ,在 有 和 母 版 页 的 情况 下 ,如果 在 内 容 页 中 需要 引入 不 同 的 Web 服务 (或 脚 
本 ) ,这 就 需要 在 内 容 页 中 使 用 ScriptManagerProxy 控件 。 下 面 通过 一 个 示例 进行 说 明 。 

【 例 15.5】 在 chl5 网 站 中 设计 一 个 母 版 页 和 两 个 使 用 Web 服务 的 内 容 页 ,说 明 在 
AJAX 内 容 页 中 引用 Web 服务 的 方法 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch15 网 站 ,创建 一 个 名 称 为 MasterPage. master 的 母 版 页 ,其 设计 界面 如 图 15. 20 
所 示 。 
@ 创建 一 个 以 MasterPage. master 为 母 版 页 的 WebForm3 网 页 ,在 其 中 放置 一 个 
ScriptManagerProxyl 控件 和 一 个 UpdatePanell 控件 。UpdatePanell 控件 的 设计 与 
WebForml 网 页 界面 相同 ,如 图 15. 21 所 示 。 


设 和 | a 拆 分 |。 源 | [4][<body>|[<form*forml>] <div> Cl [mt ] a | 天 | [4] <aspiContentsContent2> ol 


图 15.20 MasterPage. master 母 版 页 设计 界面 图 15.21 WebForm3 网 页 设计 界面 


WebForm3 网 页 中 ScriptManagerProxyl 控件 的 源 视图 代码 如 下 : 


<asp:ScriptManagerProxy ID = "ScriptManagerProxy1”runat = "server"> 
<Services> 
<asp:ServiceReference Path= "localhost. WebService.asmx" /> 


</Services > 

</asp:ScriptManagerProxy> 

它 用 于 引用 localhost. WebService. asmx 服务 。 

WebForm3 网 页 中 Button1 ( 相 加 ) 命 令 按 钮 的 
Buttonl_Click 事件 过 程 与 WebForml 网 页 的 完全 相同 。 
单 击 工具 栏 中 的 Internet Explorer 按钮 运行 本 网 页 ,其 运行 
界面 如 图 15. 22 所 示 。 

@ 再 创建 一 个 以 MasterPage. master 为 母 版 页 的 
WebForm4 网 页 ,在 其 中 放置 一 个 ScriptManagerProxy1 
控件 和 一 个 UpdatePanell 控件 。UpdatePanell 控件 的 设 
计 与 WebForm2 网 页 界面 相同 ,如 图 15. 23 所 示 。 图 15.22 WebForm3 网 页 运行 界面 


431 
第 15 章 ASP.NET Web 服 


WebForm4 网 页 中 ScriptManagerProxyl 控件 的 源 视图 代码 如 下 : 


<asp:ScriptManagerProxy ID = "ScriptManagerProxyl" runat = "server"> 
<Services> 
<asp: ServiceReference Path = "localhost. WebServicel. asmx" /> 
</Services > 
</asp:ScriptManagerProxy > 


它 用 于 引用 localhost. WebServicle. asmx 服务 。 WebForm4 网 页 的 运行 界面 如 图 15. 24 
所 示 。 


€ S 各 htpy/localhost5105 DD ~ 


| [Et ms59 | 天 | 


图 15. 23 WebForm4 网 页 设计 界面 图 15.24 WebForm4 网 页 运行 界面 


本 例 的 几 点 说 明 如 下 : 

QO@ 内 容 页 的 程序 代码 中 像 myservice. addCm、n) 调 用 的 由 ScriptManagerProxyl 的 Path 
属性 引用 的 Web 服务 ,即便 删除 Web. config 文件 中 的 二 appSettings 二 节 , WebForm3 和 
WebForm4 网 页 也 能 够 正确 运行 ,而 WebForml 和 WebForm2 网 页 就 不 能 正确 运行 了 。 

@ ScriptManagerProxyl 仅仅 用 来 引用 Web 服务 , 像 前 面 例 15. 3 中 第 @ 步 到 第 @ 步 的 
操作 不 能 省 略 ,否则 WebForm3 和 WebForm4 网 页 也 不 能 正确 运行 。 


练习 题 15 


1. 简 述 Web 服务 有 哪些 特点 。 
2. 简 述 Web 服务 的 体系 结构 。 
3. 简 述 创建 Web 服务 的 过 程 。 
4. 简 述 使 用 Web 服务 的 过 程 。 
5. 在 AJAX 内 容 页 中 如 何 引用 Web 服务 的 方法 ? 


上 机 实验 题 15 


在 本 章 创 建 的 Web 网 站 的 WebServicel. cs 文件 中 添加 一 个 名 称 为 compavg 的 Web 服 
务 ,其 参数 为 课程 名 ,返回 Stud 数据 库 中 该 课程 名 的 平均 分 。 再 在 ch15 网 站 中 添加 一 个 名 称 
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为 Examplel5 的 网 页 ,该 网 页 运行 时 用 户 选择 一 门 课程 名 后 , 单 击 * 求 平均 分 ”命令 按钮 ,调用 
该 Web 服务 并 在 标签 中 显示 计算 的 结果 。 例 如 ,运行 本 网 页 时 选择 “数据 结构 ”, 单 击 “ 求 平均 
分 ”命令 按钮 ,其 运行 界面 如 图 15. 25 所 示 。 


图 15.25 上 机 实验 题 网 页 的 运行 界面 
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配置 ASP.NET 应 用 程序 | GE 


ASP .NET 拥有 一 个 功能 强大 且 又 设置 灵活 的 配置 系统 ,主要 是 通过 
Web. config 配置 文件 设置 的 。 本 章 介绍 Web. config 配置 文件 的 格式 和 配置 
Web 应 用 程序 的 方法 。 

本 章 学 习 要 点 : 

加 掌握 Web. config 配置 文件 的 作用 。 

加 掌握 Web. config 配置 文件 的 结构 。 

回 掌握 Web. config 配置 文件 的 设置 方法 。 

回 掌握 Web. config 配置 文件 的 加 密 和 解密 过 程 。 

回 掌握 ASP.NET 安全 机 制 ,特别 是 表单 验证 过 程 。 


16.1 Web. config 配置 文件 概述 


Web. config 配置 文件 是 一 个 XML 文本 文件 ,用 于 存放 ASP.NET Web 应 
用 程序 的 配置 信息 。 在 创建 网 站 时 会 自动 建立 Web. config 文件 ,位 于 网 站 根 
目录 下 。 


16.1.1 Web. config 文件 的 特点 


Web. config 文件 的 特点 如 下 : 

在 运行 时 对 Web. config 文件 的 修改 不 需要 重启 服务 就 可 以 生效 。 
ASP.NET 可 以 自动 监测 到 配置 文件 的 更 改 并 且 将 新 的 配置 信息 自动 
进行 应 用 ,无 须 管理 人 员 手 工 干预 。 

易于 编辑 和 理解 , Web. config 文件 是 基于 XML 的 文本 文件 ,其 设置 易 
于 阅读 ,可 以 使 用 任何 文本 编辑 工具 来 编辑 。 

ASP.NET 提供 了 配置 信息 加 密 机 制 , 可 对 重要 信息 进行 加 密 。 

Web. config 文件 是 可 以 扩展 的 ,可 以 自 定义 新 配置 参数 并 编写 配置 节 
处 理 程序 以 对 它们 进行 处 理 。 

ASP. NET 提供 了 专门 用 可 视 化 工具 对 网 站 进行 配置 的 管理 模式 。 
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。 Web. config 文件 是 一 个 基于 XML 格式 的 配置 文件 ,所 以 必须 在 其 中 包含 成 对 的 标 
记 , 即 开始 标记 与 结束 标记 必须 成 对 出 现 , 而 且 是 区 分 大 小 写 的 ,在 编辑 Web. config 
文件 时 需 特别 注意 。 开 发 人 员 可 以 用 任意 标准 的 文本 编辑 器 XML 解析 器 和 脚本 语 
言 解释 ,修改 配置 内 容 。 

。 Web. config 文件 可 将 配置 的 有 关 设 置 保存 在 该 文件 中 而 不 对 注册 表 做 任何 改动 ,所 
以 只 需 将 Web. config 文件 复制 到 另 一 服务 器 相应 的 目录 中 就 可 以 方便 地 把 该 应 用 配 
置 传 到 另 一 服务 器 之 中 。 


16.1.2 配置 文件 的 继承 关系 


Web. Config 文件 可 以 出 现在 应 用 程序 的 每 一 个 目录 中 。 当 新 建 一 个 Web 应 用 程序 后 ， 
默认 情况 下 会 在 根 目录 自动 创建 一 个 默认 的 Web. config 文件 ,包括 默认 的 配置 设置 ,所 有 的 
子 目录 都 继承 它 的 配置 设置 。 如 果 要 修改 子 目 录 的 配置 设置 ,可 以 在 该 子 目 录 下 新 建 一 个 
Web. config 文件 。 它 可 以 提供 除 从 父 目 录 继 承 的 配置 信息 以 外 的 配置 信息 ,也 可 以 重 写 或 修 
改 父 目录 中 定义 的 设置 。 

所 有 的 ASP.NET 应 用 程序 配置 都 继承 本 地 服务 器 上 的 一 个 “总 ”的 ASP.NET 配置 文 
件 , 它 位 于 “*% systemroot%\Microsoft. NET\Framework\versionNumber\CONFIG\ Web. 
config” 目 录 ( 如 C:\Windows\Microsoft. NET\Framework\v4.0.30319\CONFIG), 称 为 根 
Web. config。 

由 于 每 个 ASP.NET 应 用 程序 都 从 根 Web. config 文件 那里 继承 默认 设置 ,因此 对 于 每 个 
ASP.NET 应 用 程序 ,只 需要 重 写 必要 的 配置 信息 即 可 。 

另外 , 根 Web. config 从 “顶级 ”的 machine. config 文件 (与 根 Web. config 位 于 相同 目录 ) 
那里 继承 一 些 基本 的 配置 设置 ,machine. config 文件 中 的 某 些 设置 不 能 在 Web. config 文件 中 
被 重 写 。 

Web. config 文件 的 继承 关系 为 machine. config( 服 务 器 ) 一 根 Web. config 一 网 站 Web. 
config( 网 站 级 ) 一 Web. config(ASP.NET 应 用 程序 根 目录 ) 一 Web. config(ASP.NET 应 用 程 
序 子 目 录 ) 一 应 用 程序 名 称 . config( 客 户 端 应 用 程序 目录 )。 后 面 的 配置 信息 可 以 继承 并 覆盖 
前 面 的 设置 。 

说 明 : .NET Framework 4.5 实际 上 是 v4. 0. 30319 版 本 。.NET Framework 支持 并 行 执 
行 模式 ,如 果 服 务 器 上 安装 了 多 个 版 本 ,就 会 有 多 个 machine. config 文件 。. NET Framework 
3 和 3.5 建立 在 .NET Framework 2.0 基础 之 上 ,因此 ,.NET Framework 3 和 3.5 使 用 与 ， 
NET Framework 2.0 相同 的 machine. config 文件 ,而 .NET Framework 4 是 全 新 的 CLR ,不 
像 .NET Framework 3 和 3.5 那样 依赖 . NET Framework 2.0。..NET Framework 4 有 自己 的 
machine. config 文件 。.NET Framework 4. 5 也 不 同 , 它 是 . NET Framework 4 的 改进 版 ，. 
NET Framework 4 最 初 的 库 由 .NET Framework 4.5 替代 。 


16.2 Web. config 文件 


16.2.1 Web. config 文件 的 结构 
Web. config 文件 是 基于 XML 的 文本 文件 ,可 出 现在 ASP.NET Web 应 用 程序 服务 器 上 
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的 任何 目录 中 。 每 个 Web. config 文件 将 配置 设置 应 用 到 它 所 在 的 目录 和 它 下 面 的 所 有 子 
目录 。 
说 明 : XML 是 一 种 将 结构 化 信息 表示 为 文本 的 简单 而 且 通 用 的 格式 ,采用 分 层 并 以 节 为 
中 心 表示 信息 ,一 个 节 可 以 庶 套 其 他 子 节 ,其 使 用 十 分 灵活 。Web. config 文件 的 实质 就 是 采 
用 XML 保存 Web 应 用 系统 中 的 配置 信息 。 
Web. config 文件 的 所 有 配置 信息 都 做 套 在 二 configuration 之 根 元素 中 ,其 常用 的 
configuration 子 元 素 如 下 。 
。 location: 把 指定 的 权限 应 用 于 某 个 特定 的 文件 或 目录 。 其 主要 属性 path 指定 应 用 包 
含 的 配置 设置 的 资源 ,使 用 不 带 path 的 location 将 配置 设置 应 用 于 当前 目录 及 其 所 有 
子 目 录 。 
。 configSections: 指定 配置 节 和 命名 空间 声明 。 
。 appSettings: 包含 自 定义 应 用 程序 设置 ,如 文件 路 径 或 存储 在 应 用 程序 中 的 任何 
信息 。 
。 connectionStrings: 为 ASP. NET 应 用 程序 和 功能 指定 数据 库 连 接 字 符 串 (名 称 / 值 对 
的 形式 ) 的 集合 。 
通常 配置 信息 分 为 两 个 主 区 域 , 即 指定 配置 节 和 命名 空间 声明 以 及 配置 节 设置。 
1. 指定 配置 节 和 命名 空间 声明 
采用 configSections 元 素 指定 配置 节 和 命名 空间 声明 。 它 出 现在 配置 文件 项 部 ,包含 在 
去 section 过 标记 中 的 每 个 声明 都 指定 提供 特定 配置 数据 集 的 节 名 和 处 理 该 节 中 配置 数据 的 
.NET Framework 类 的 名 称 。 王 configSections 二 节 的 基本 格式 如 下 : 


<configSections > 
< section /> 
< sectionGroup /> 
< remove /> 
<clear/> 
</configSections > 

其 中 ,clear 移 除 对 继承 的 节 和 节 组 的 所 有 引用 ,只 允许 由 当前 section 和 sectionGroup 元 
素 添 加 的 节 和 节 组 。remove 移 除 对 继承 的 节 和 节 组 的 引用 。section 称 为 节 , 用 于 定义 配置 
节 处 理 程序 与 配置 元 素 之 间 的 关联 。sectionGroup 称 为 节 组 ,用 于 定义 配置 节 处 理 程序 与 配 
置 节 之 间 的 关联 ,sectionGroup 元 素 充 当 section 元 素 的 容器 。 

每 个 section 元 素 标识 一 个 配置 节 或 元 素 以 及 对 该 配置 节 或 元 素 进 行 处 理 的 关联 
ConfigurationSection 派生 类 ,可 以 在 sectionGroup 元 素 中 对 section 元 素 进行 逻辑 分 组 ,以 对 
section 元 素 进行 组 织 并 避免 命名 冲突 。 

在 Web. config 文件 中 不 一 定 有 configSections 元 素 . 但 如 果 包 含 configSections 元 素 , 该 
元 素 必 须 是 configuration 元 素 的 第 一 个 子 元 素 , ASP. NET 会 将 配置 数据 的 处 理 委托 给 其 中 
指定 的 配置 节 处 理 程序 。 

例如 ,以 下 代码 来 自 Machine. config 文件 .用 于 定义 system. web 节 中 authentication 元 
素 的 配置 节 处 理 程序 : 


<configSections > 
< sectionGroup name = "system. web" 
type = "System. Web. Configurat ion. SystemWebSectionGroup, System. Web, 
Version = % ASSEMBLY VERSION% , Culture = neutral, 
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PublicKeyToken = % MICROSOFT PUBLICKEY % "> 
< section name = "authentication" 
type = "System. Web. Configurat ion. Authent icationSection, System.Web, 
Version = 2.0.3600.0, Culture = neutral, PublicKeyToken = b03f5f7f11d50a3a" 
allowDef inition = "MachineToAppl ication" /> 


<! -- 其 他 system. web 节 一 -> 
</sectionGroup> 
<! -- 其 他 配置 节 -一 > 
</conf igSections > 
如 果 配 置 节 处 理 程序 不 与 某 个 配置 元 素 关联 ,ASP.NET 将 发 出 服务 器 错误 “无 法 识别 的 
配置 节 元 素 名 称 ”。 
说 明 : 在 初学 Web 系统 开发 时 很 少 使 用 二 configSections 记 节 , 通 过 这 里 的 介绍 希望 给 读 
者 一 个 关于 配置 文件 的 整体 概念 。 
2. 配置 节 的 设置 


配置 节 设 置 区 域 位 于 二 configSections 二 之 后 ,这 部 分 包含 实际 的 配置 设置 。 
到 configSections 之 区 域 中 的 每 个 声明 都 有 一 个 配置 节 。 每 个 配置 节 都 包含 子 标记 ,这 些 子 标 
记 带 有 包含 该 节 设 置 的 属性 。 

例如 ,一 个 Web. config 文件 包含 以 下 配置 : 


<configuration> 
<configSections > 
< sectionGroup name = "mySectionGroup"> 
< section name = "mySection" 
type = "System. Configuration. NameValueSectionHandler" /> 
</sectionGroup> 
</configSections> 
<mySectionGroup > 
<mySection> 
<add key = "keyl" value = "valuel" /> 
</mySection> 
</mySectionGroup > 
</configuration> 


其 中 ,在 配置 节 处 理 程序 声明 区 域 配置 了 一 个 节 组 mySectionGroup ,包含 一 个 mySection 
节 , 其 处 理 程序 为 System. Configuration. NameValueSectionHandler。 在 配置 节 设 置 区 域 中 
定义 的 mySection 配置 节 有 一 个 键 为 keyl ,其 值 为 valuel 。 


16.2.2 重要 的 配置 节 


system. web 元 素 指 定 ASP.NET 配置 节 的 根 元 素 , 并 包含 用 于 配置 ASP.NET Web 应 
用 程序 和 控制 其 行为 的 元 素 。Web. config 文件 的 一 些 重 要 的 配置 节 如 下 : 


<configuartion> 

< System. web > 
<<httpRuntime /> 
<pages /> 
< compilation /> 
<customErrors /> 
<authentication /> 
<authorization /> 
< identity /> 


<trace /> 


< sessionState /> 
<httpHandlers /> 
<httpModules /> 

< globalization /> 


</system. web > 
</configuration> 
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上 述 常 用 子 元 素 及 其 说 明 如 表 16. 1 所 示 。 


表 16.1 常用 子 元 素 及 其 说 明 


元 素 说 明 
httpRuntime> 配置 ASP.NET HTTP 运行 库 设 置 
<pages> 标识 特定 于 页 的 配置 设置 


=compilation> 
customErrors> 
=authentication> 
authorization> 
< 一 identity 二 
=trace> 
=sessionState> 


httpHandlers> 


一 globalization 二 
compilation> 


配置 ASP. NET 使 用 的 所 有 编译 设置 

为 ASP.NET 应 用 程序 提供 有 关 自 定义 错误 信息 的 信息 
配置 ASP.NET 身份 验证 支持 

配置 ASP.NET 授权 支持 ,控制 对 URL 资源 的 客户 端 访 问 
控制 Web 应 用 程序 的 应 用 程序 标识 

配置 ASP.NET 跟踪 服务 

为 当前 应 用 程序 配置 会 话 状态 设置 

根据 在 请 求 中 指定 的 URL 和 HTTP 谓词 将 传人 的 请 求 映射 到 适当 的 
IHttpHandler 或 1HttpHandlerFactory 类 

配置 应 用 程序 的 全 球 化 设置 

配置 ASP.NET 使 用 的 所 有 编译 设置 


下 面 介绍 一 些 常用 子 元 素 的 使 用 方法 。 


1. 二 httpRuntime 二 节 


一 httpRuntime 之 节 用 于 配置 ASP.NET HTTP 运行 时 设置 ,以 确定 如 何 处理 对 ASP. 


NET 应 用 程序 的 请 求 。 


例如 ,控制 用 户 上 传 文件 最 大 为 4MB(4096B) ,最 长 时 间 为 60 秒 ,最 多 请 求 数 为 100， 


<httpRuntime maxRequestLength = "4096" executionTimeout = "60" 
appRequestQueueLimit = "100"> 


</httpRunt ime > 


2. 一 pages 二 节 


去 pages 二 节 用 于 全 局 定义 页 特定 配置 设置 ,如 配置 文件 范围 内 的 页 和 控件 的 ASP.NET 
指令 。 对 于 单个 网 页 等 同 于 @ Page 指令 。 

例如 ,不 检测 用 户 在 浏览 器 输入 的 内 容 中 是 否 存在 潜在 的 危险 数据 ,在 从 客户 端 回 发 页 时 
将 检查 加 密 的 视图 状态 ,以 验证 视图 状态 是 否 已 在 客户 端 被 自 改 : 


< pages buffer = "true" enableViewStateMac = "true" 
validateRequest = "false"> 


</pages> 


3. 二 compilation 二 节 


二 compilation 之 节 用 于 配置 ASP.NET 用 于 编译 应 用 程序 的 所 有 编译 设置 。ASP. NET 
支持 调试 模式 下 编译 的 应 用 程序 ,但 是 应 用 程序 的 性 能 受到 影响 。 在 默认 状态 下 调试 被 禁用 。 
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车 要 启用 调试 ,设置 二 compilation 请 节 如 下 : 


<compilation 
debug= "false" > 
</compilation> 


4. 二 customErrors 二 节 
<customErrors 之 节 用 于 为 ASP.NET 应 用 程序 提供 有 关 自 定义 错误 信息 的 信息 。 它 不 
适用 于 Web 服务 中 发 生 的 错误 。 其 子 元 素 为 error( 可 选 ), 用 于 指定 给 定 HTTP 状态 代码 的 
自 定义 错误 页 。 其 属性 及 说 明 如 表 16. 2 所 示 。 
其 子 元 素 有 error( 可 选 的 元 素 ), 用 于 指定 给 定 HTTP 状态 代码 的 自 定义 错误 网 页 。 
error 可 以 出 现 多 次 ,每 一 次 出 现 均 定 义 一 个 自 定义 错误 条 件 。 
表 16.2 ”一 customErrors 二 节 的 属性 及 其 说 明 


属 性 说 明 

defaultRedirect 可 选 的 属性 ,指定 出 错时 将 浏览 器 定向 到 的 默认 URL。 如 果 未 指定 该 属性 , 则 显示 一 般 性 
错误 。URL 可 以 是 绝对 的 (如 www. contoso. com/ ErrorPage. htm) 或 相对 的 。 相 对 URL 
(如 /ErrorPage. htm) 是 相对 于 为 该 属性 指定 URL 的 Web. config 文件 ,而 不 是 相对 于 发 生 
错误 的 网 页 。 以 波形 符 (一 ) 开 头 的 URL( 如 一 /ErrorPage. htm) 表 示 指 定 的 URL 是 相对 
于 应 用 程序 的 根 路 径 

mode 必 选 的 属性 ,指定 是 启用 或 禁用 自 定 义 错误 ,还 是 仅 向 远程 客户 端 显 示 自 定义 错误 ,此 属 
性 可 以 为 下 列 值 之 一 。 
@ On: 指定 启用 自 定义 错误 ,会 向 远程 客户 端 和 本 地 主机 显示 自 定义 错误 
@ Off: 指定 禁用 自 定义 错误 ,会 向 远程 客户 端 和 本 地 主机 显示 详细 的 ASP.NET 错误 
@ RemoteOnly( 默 认 值 ): 指定 仅 向 远程 客户 端 显 示 自 定义 错误 并 且 向 本 地 主机 显示 ASP 
.NET 错误 


例如 有 以 下 配置 : 


<configuration> 
<systenm. web > 
< customErrors defaultRedirect = "ErrorPage. aspx" 
mode = "RemoteOnly"> 
<error statusCode = "500" 
redirect = "InternalError. htm"/> 
</customErrors > 
</system. web > 
</configuration > 
当 网 页 发 生 运行 错误 时 ,将 跳 转 到 ErrorPage. aspx 网 页 ; 如 果 是 500 错误 , 则 跳 转 到 
InternalError. htm 网 页 。 
5. 一 authentication 二 节 
到 authentication 过 节 为 ASP.NET 应 用 程序 配置 ASP.NET 身份 验证 模式 。 身 份 验证 
方案 确定 如 何 识别 要 查看 ASP.NET 应 用 程序 的 用 户 。 其 mode 属性 指定 身份 验证 模式 , 它 
是 必 选 的 属性 ,其 取 值 如 表 16. 3 所 示 。 
其 他 子 元 素 如 下 。 
。forms: 为 基于 窗 体 的 自 定义 身份 验证 配置 ASP.NET 应 用 程序 。 
。 passport: 指定 要 重 定向 到 的 网 页 。 
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表 16.3 mode 属性 的 取 值 及 其 说 明 


取 值 说 明 
Windows( 默 认 值 》 指定 为 Windows 身份 验证 模式 
Forms 指定 为 表单 身份 验证 模式 
Passport 由 Microsoft 提供 的 集中 身份 验证 服务 ,用 于 为 成 员 网 站 提供 单一 登录 和 核心 配置 服务 
None 不 指定 任何 身份 验证 。 应 用 程序 仅 期 待 匿 名 用 户 , 和 否则 它 将 提供 自己 的 身份 验证 


有 关 身 份 验证 的 详细 内 容 将 在 16. 4 节 讨 论 。 
6. 一 authorization 二 节 
去 authorization 之 节 配 置 Web 应 用 程序 的 授权 ,以 控制 客户 端 对 URL 资源 的 访问 (如 允 
许 匿名 用 户 访问 )。 此 元 素 可 以 在 任何 级 别 ( 计 算 机 、 网 站 、 应 用 程序 、 子 目录 或 页 ) 上 声明 , 且 
必须 与 王 authentication 之 节 配 合 使 用 ,其 子 元 素 如 下 。 
。 allow: 向 授权 规则 映射 添加 一 个 规则 ,该 规则 允许 对 资源 进行 访问 。 
。 deny: 向 授权 规则 映射 添加 一 条 拒绝 对 资源 的 访问 的 授权 规则 。 
例如 ,以 下 代码 允许 所 有 Admins 角色 成 员 进 行 访问 并 拒绝 所 有 users 角色 成 员 进 行 
访问 ， 
<configuration > 
< System. web > 
<authorization > 
<allow roles= "Admins"/> 
<deny users ="* "/> 
</authorization> 
</system. web > 
</configuration > 
又 如 ,以 下 代码 阻止 除了 被 指派 为 Managers 角色 外 的 任何 用 户 访问 Management 文件 
目录 : 
< location path= "Management"> 
< system. web > 


<authorization> 
<allow roles = "Managers" /> 


<deny users="*"/> 


</authorization> 
</system. web > 

</location> 

users 属性 指出 可 访问 的 账号 , 当 为 *?” 时 表示 匿名 用 户 , 当 为 ** "时 表示 所 有 用 户 。 

说 明 : ASP.NET 应 用 程序 不 会 验证 path 属性 中 指定 的 路 径 。 如 果 路 径 无 效 ,ASP.NET 
就 不 会 应 用 安全 设置 。 

不 像 二 authentication 二 节 , 一 authorization 之 节 并 没有 被 限制 在 Web 应 用 程序 根 目录 下 
面 的 Web. config 文件 中 ,相反 ,用 户 可 以 在 任何 子 目录 中 使 用 它 ,这 样 可 以 为 不 同 组 的 网 页 设 
置 不 同 的 授权 规则 。 

7. 一 trace 二 节 

< 到 trace 盖 节 配 置 ASP. NET 代码 跟踪 服务 以 控制 如 何 收集 、 存 储 和 显示 跟踪 结果 。 例 
如 ,以 下 为 Web. config 中 的 默认 配置 : 
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<trace 
enabled = "false" 
localOnly = "true" 
mostRecent = "false" 
pageOQutput = "false" 
requestLimit = "10" 
traceMode = "SortByTime" 
writeToDiagnosticsTrace = "false" /> 
其 中 ,enabled 一 "false" 表 示 不 启用 跟踪 (如 果 设 置 为 true, 表 示 启 动 跟踪 ,在 应 用 程序 执 
行 完毕 后 , 它 会 将 跟踪 情况 保存 到 一 个 系统 文件 trace. axd 中 )。localOnly 一 "true" 表 示 跟 踪 
查看 器 只 用 于 宿主 Web 服务 器 。mostRecent 二 "false" 表 示 显 示 请 求 跟踪 的 数据 ,直至 达到 
requestLimit 特性 指定 的 限制 。pageOutput 一 "false" 表 示 只 能 通过 跟踪 实用 工具 访问 跟踪 输 
出 。reqduestLimit 一 " 10" 表示 指定 在 服务 器 上 存储 的 跟踪 请 求 的 数目 。traceMode 一 
"SortByTime" 表 示 以 处 理 跟踪 的 顺序 来 显示 跟踪 信息 。 
8. 二 sessionState 二 节 
过 sessionState 二 节 为 当前 应 用 程序 配置 会 话 状态 设置 (如 设置 是 否 启用 会 话 状态 ,会 话 
状态 保存 位 置 )。 例 如 ,有 以 下 设置 : 


< sessionState mode = "InProc" cookieless = "true" timeout = "20"></sessionState > 


其 中 ,mode 二 "InProc" 表 示 在 本 地 储存 会 话 状 态 ( 也 可 以 选择 储存 在 远程 服务 器 或 SAL 
服务 器 中 或 不 启用 会 话 状态 ) 。cookieless= "true" 表 示 用 户 浏览 器 不 支持 cookie 时 启用 会 话 
状态 (默认 为 false) 。timeout 王 "20" 表 示 会 话 可 以 处 于 空闲 状态 的 20 分 钟 。 

在 IIS 中 配置 网 站 或 虚拟 目录 时 可 能 会 导致 自动 修改 相应 Web. config 的 内 容 ,下 面 通过 
一 个 示例 来 说 明 。 

【 例 16.1】 在 D 盘 ASP.NET 目录 中 建立 一 个 ch16 的 子 目录 ,将 其 作为 第 15 章 创建 的 
Web 网 站 的 虚拟 目录 ,然后 创建 一 个 Default. aspx 网 页 ,并 将 该 网 页 作为 主页 。 

解 : 其 步骤 如 下 。 

@ 进入 "Internet 信息 服务 (IIS) 管 理 器 "对话 框 。 

@ 右 击 第 15 章 创 建 的 “Web” 网 站 ,在 出 现 的 快捷 菜单 中 选择 “添加 虚拟 目录 ”命令 ,出 现 
“添加 虚拟 目录 ”对 话 框 ,输入 别名 “ch16”, 指 定 物 理 路 径 为 *“D:\ASP.NET\ch16”, 如 图 16.1 
所 示 , 单 击 “ 确 定 ” 按 钮 ,这 样 就 建立 了 ch16 虚拟 目录 。 

说 明 : 虚拟 目录 可 以 在 不 影响 现 有 网 站 的 情况 下 实现 服务 器 磁盘 空间 的 扩展 ,而 且 虚 拟 
目录 可 以 与 原 有 网 站 不 在 同一 个 文件 夹 ,不 在 同一 个 磁盘 驱动 器 ,甚至 不 在 同一 台 计 算 机 上 ， 
但 用 户 在 访问 网 站 时 却 感觉 不 到 任何 区 别 。 如 果 要 访问 虚拟 目录 ,用 户 必须 知道 虚拟 目录 的 
别名 ,并 在 浏览 器 中 输入 URL, 例 如 “http://localhost/ch16/”。 

@ 右 击 ch16 虚拟 目录 ,在 出 现 的 快捷 菜单 中 选择 “转换 为 应 用 程序 ”命令 ,在 出 现 的 对 话 
框 中 单 击 “ 确 定 ” 按 钮 。 

说 明 : 如 果 没 有 本 步骤 的 操作 ,在 第 四 步 新 建 网 站 时 会 出 现 *“ 网 站 ch16 没有 在 IIS 中 标记 
为 一 个 应 用 程序 ”的 提示 框 。 

@ 双击 “身份 验证 ”项 ,出 现 “ 身 份 验证 ”对 话 框 ,然后 右 击 *Forms 身份 验证 ”项 ,在 出 现 的 
快捷 菜单 中 选择 “编辑 ”命令 , 出现“ 编辑 Forms 身份 验证 设置 ”对话 框 ,将 登录 URL 改 为 
“Default. aspx”, 如 图 16. 2 所 示 , 单 击 “ 确 定 ” 按 钮 。 


441 


第 16 章 配置 ASP.NET 应 用 程 


ch16 

示 姓 肌 你 
物理 路 径 (P): 
DAASP.NET\ch16 


图 16.1 “添加 虚拟 目录 ”对 话 框 图 16.2 “编辑 Forms 身份 验证 设置 "对 话 杠 


@ 双击 “授权 规则 ”项 ,在 “操作 ” 窗 格 中 单 击 “ 添 加 拒绝 规则 ”, 出现“ 添加 拒绝 授权 规则 ” 
对 话 框 ,选择 “所 有 匿名 用 户 ” 单 选 按钮 ,如 图 16. 3 所 示 , 然 后 单 击 “ 确 定 ” 按 钮 返回 。 


图 16.3 “添加 拒绝 授权 规则 ”对 话 框 


@ 双击 “连接 字符 串 " 项 ,其 中 默认 的 连接 字符 串 如 下 : 


data source = . \SQLEXPRESS; Integrated Security = SSPI; 
AttachDBFilename = |DataDirectory|aspnetdb. mdf ;User Instance = true 


在 “操作 ” 窗 格 中 单 击 “ 编 辑 ”, 出现“ 编辑 连接 字符 串 ” 对 话 框 ,修改 其 如 图 16.4 所 示 ( 图 中 
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自动 隐藏 了 输入 的 密码 ) , 单 击 “ 确 定 ” 按 钮 返回 。 


至 二 桥 (D): 
SEE 

使 用 Windows 集成 安全 性 (W) 
口 描 宇 美雪 (P) 


设置 人 


回 自 定义 (M) 


Data Source=LCB-PO\SQLEXPRESS; Initial Catalog=Stud;User ID=sa;Password= ~ 
ee 


CGC) 


16.4 “编辑 连接 字符 串 " 对 话 框 


@ 启动 Visual Studio 2012 ,选择 "文件 | 新 建 | 网 站 ”命令 ,出 现 * 新 建 网 站 ?对话 框 ,然后 
选择 "ASP.NET 空 网 站 ”模板 ,选择 "Web 位 置 " 为 “HTTP”, 单 击 “ 浏 览 ” 按 钮 ,选择 本 地 IIS 
中 Web 下 方 的 ch16 , 单 击 “确定 ”按钮 ,这 样 就 创建 了 一 个 空 网 站 ch16, 其 URL 为 “http:// 
localhost/ ch16/”。 

@@ 打开 Web. config 文件 ,看 到 内 容 如 下 : 


<?xml version = "1.0" encoding = "UTF — 8"?> 
<configuration> 
<systenm. web > 
<authentication> 
< forms loginUrl = "Default. aspx" /> 
</authentication> 
</system. web > 
< System. webServer > 
<security> 
< authorization> 
<add accessType = "Deny" users="?" /> 
</authorization > 
</security> 
</system. webServer > 
< connectionStrings > 
< remove name = "LocalSqlServer" /> 
<add connectionString = "Data Source = LCB - PC\ SOLEXPRESS; 
Initial Catalog = Stud; User ID = sa;Password = 12345" name= "LocalSqlServer" 
providerName = "System. Data. SqlClient" /> 
</connectionStrings > 
</configuration > 
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从 中 看 到 用 户 的 操作 都 反映 在 上 述 代码 中 。 

说 明 : system. webServer 节 是 在 IIS 7.0 或 更 高 版 本 中 引入 的 ,用 于 设置 一 些 网 站 级 和 应 
用 程序 级 的 配置 设置 。 该 节 是 在 IIS 7.0 下 运行 ASP.NET AJAX 所 必需 的 ,对 于 早期 版 本 的 
JIS 不 是 必需 的 。 


16.2.3 在 Web.config 中 保存 自 定义 的 设置 


用 户 可 以 在 一 appSettings 二 节 和 一 connectionStrings 二 节 设 置 一 些 应 用 程序 的 设置 项 。 

1. 一 appSettings 二 节 

此 节 用 于 定义 应 用 程序 设置 项 。 对 于 一 些 不 确定 设置 ,还 可 以 让 用 户 根据 自己 的 实际 情 
况 设置 。 例 如 在 其 中 添加 用 于 存储 数据 库 连 接 字符 串 的 子 结 点 ,当然 ,如 果 程 序 需 要 其 他 自 定 
义 的 全 局 配置 信息 ,也 可 以 在 此 添加 相应 的 子 结 点 。 

appSettings 元 素 的 子 元 素 如 下 : add( 可 选 的 子 元 素 ) 向 应 用 程序 设置 集合 添加 名 称 / 值 对 
形式 的 自 定义 应 用 程序 设置 ; clear( 可 选 的 子 元 素 ) 移 除 所 有 对 继承 的 自 定义 应 用 程序 设置 的 
引用 , 仅 允 许 由 当前 add 属性 添加 的 引用 ; remove( 可 选 的 子 元 素 ) 从 应 用 程序 设置 集合 中 移 
除 对 继承 的 自 定义 应 用 程序 设置 的 引用 。 

例如 ,在 Web. config 文件 的 一 appSettings 二 节 中 采用 一 add 二 添加 了 一 个 与 SQL Server 
数据 库 Stud 连接 的 子 结 点 和 一 个 Web 服务 子 结 点 : 

<appSettings > 

<add key= "myconnstringl" 
value = "Data Source = LCB - PC\SQLEXPRESS; Initial Catalog= Stud; 
User ID = sa;Password = 12345" /> 
</appSettings > 

可 以 使 用 System. Configuration. ConfigurationManager. AppSettings. Get ("key 值 ") 来 
读 取 二 appSettings 二 节 中 的 子 结 点 值 。 其 中 ,Get 方法 总 是 返回 一 个 字符 串 , 可 以 转换 为 所 需 
要 的 类 型 。 以 下 代码 用 于 获取 过 appSettings 之 节 中 myconnstringl 子 结 点 的 值 : 

mystr = System. Conf iguration. ConfigurationManager. AppSettings. Get("myconnstringl") ; 

2. 二 connectionStrings 二 节 

此 节 用 于 定义 连接 字符 串 , 在 ASP.NET 中 ,会 话 、 成 员 资格 .个 性 化 设置 和 角色 管理 器 等 
功能 均 依赖 于 存储 在 connectionStrings 元 素 中 的 连接 字符 串 , 还 可 以 使 用 connectionStrings 
元 素来 存储 应 用 程序 的 连接 字符 串 。 

connectionStrings 元 素 的 子 元 素 如 下 : add 子 元 素 向 连接 字符 串 集 合 添加 名 称 / 值 对 形式 
的 连接 字符 串 ; clear 子 元 素 移 除 所 有 对 继承 的 连接 字符 串 的 引用 , 仅 允 许 那 些 由 当前 的 add 
元 素 添加 的 连接 字符 串 ; remove 子 元 素 从 连接 字符 串 集合 中 移 除 对 继承 的 连接 字符 串 的 
引用 。 

例如 ,在 Web. config 文件 的 二 connectionStrings 二 节 中 采用 一 add 二 添加 了 一 个 与 SQL 
Server 数据 库 school 连接 的 子 结 点 : 


<connectionStrings > 
< remove name = "myconnstring" /> 
<add name = "myconnstring” 
connectionString = "Data Source = localhost; 
Initial Catalog = Stud; Integrated Security= False; 
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User Id= sa;Password= 12345;" 
providerName = "System. Data. SqlClient" /> 
</connectionStrings > 
对 于 所 connectionStrings 之 节 中 的 子 结 点 的 Web 应 用 程序 配置 信息 ,可 以 使 用 System. 
Configuration. ConfigurationManager. ConnectionSettings[ " key 值 "]. ToString() 来 读 取 这 些 
子 结 点 值 ,例如 : 


mystr = System.Configuration. ConfigurationManager. 
ConnectionStrings[ "myconnstring"].ToString(); 


二 connectionStrings 记 节 是 从 .NET Framework 2.0 开始 引入 的 ,在 以 前 的 版 本 中 ,连接 
字符 串 存储 在 二 appSettings 之 节 中 。 尽 管 在 ASP.NET 4. 5 中 连接 字符 串 可 以 存储 在 这 两 个 
节 中 ,但 最 好 使 用 专用 的 王 connectionStrings 之 节 存 储 连 接 字符 串 。 


16.3 ”Web. config 文件 的 加 密 和 人 解密 


Web. config 文件 中 可 能 包含 数据 库 连接 字符 串 和 其 他 敏感 信息 ,通常 需要 对 其 加 密 和 人 解 
密 , 其 方法 有 多 种 ,这 里 介绍 如 何 使 用 命令 行 工具 aspnet_regiis. exe 对 配置 节 进 行 加 密 和 

在 Windows 中 单 击 “开始 ”按钮 .选择 “所 有 程序 | Microsoft Visual Studio 2012 | Visual 
Studio Tools|VS2012 x86 本 机 工具 命令 提示 ”命令 ,然后 输入 aspnet_regiis 命令 即 可 启动 
aspnet_regiis 工具 ,不 带 任何 参数 时 显示 该 工具 的 帮助 文档 。 


16.3.1 Web. config 文件 的 加 密 


加 密 一 个 特定 网 站 的 Web. config 文件 的 通用 格式 如 下 : 
aspnet_regiis 一 pef 节 名 网 站 物理 路 径 


aspnet_regiis. - pe 节 名 -app 网 站 虚拟 目录 


其 中 ,参数 -pef 表示 对 指定 物理 路 径 的 网 点 的 配置 节 进 行 加 密 , 参 数 -pe 表示 对 指定 虚拟 
目录 的 网 点 的 配置 节 进行 加 密 。 
【 例 16.2】 若 ch16 网 站 中 Web. config 文件 的 二 connectionStrings 二 节 的 代码 如 下 ,将 
其 进行 加 密 , 并 查看 加 密 后 的 内 容 。 
<connectionStrings > 
<add name = "myconnstring" connectionString = "Data 
Source = LCB - PC\SQLEXPRESS; Initial Catalog = Stud;User ID = sa;Password = 12345" 
providerName = "System. Data. SqlClient" /> 
<add name = "StudConnectionString" connectionString = "Data 
Source = LCB— PC\SQLEXPRESS; Initial Catalog = Stud; User ID = sa;Password = 12345" 
providerName = "System.Data. SqlClient" /> 
</connectionStrings > 


解 : 其 步骤 如 下 。 
@ 该 节 的 加 密 过 程 如 图 16. 5 所 示 , 表 示 成 功 加 密 。 


| 445 
第 16 章 配置 ASP.NET 应 用 程 园 


国 合理 员 : VS2012 x86 本 机 工具 仿 令 提示 


:\Progran Piles 


图 16.5 加 密 操作 


@ 打开 Web. config 文件 ,看 到 一 connectionStrings 二 节 变 为 ， 


<connectionStrings configProtectionProvider = "RsaProtectedConf igurat ionProvider"> 
< EncryptedData Type = "http://www. w3. org/2001/04/xmlenc# Element" 
xmlns= "http://www.w3.org/2001/04/xmlenc#"> 
< EncryptionMethod Algorithm = "http://www.w3.org/2001/04/xmlenc# tripledes - cbc" /> 
< KeyInfo xmlns = "http://www.w3.org/2000/09/xmldsig# "> 
< EncryptedKey xmlns = "http://www.w3.org/2001/04/xmlenc#"> 
< EncryptionMethod Algorithm = "http://www. w3. org/2001/04/xmlenc# rsa-1_5" /> 
< KeyInfo xmlns = "http://www. w3. org/2000/09/xmldsig 井 "> 
< KeyName > Rsa Key </KeyName > 
</KeyInfo> 
<CipherData> < CipherValue >…</CipherValue ></CipherData> 
</EncryptedKey > 
</KeyInfo> 
< CipherData>< CipherValue>…</CipherValue ></CipherData > 
</EncryptedData> 


</connectionStrings > 

其 中 省 略 部 分 为 加 密 字符 值 。 

说 明 : 在 请 求 应 用 程序 中 的 网 页 或 其 他 ASP.NET 资源 时 ,ASP.NET 会 对 受 保护 配置 
节 调 用 提供 程序 ,以 解密 信息 供 ASP.NET 和 应 用 程序 代码 使 用 。 
16.3.2 Web. config 文件 的 解密 

解密 一 个 特定 网 站 的 Web. config 文件 的 通用 格式 如 下 : 

aspnet_regiis -pdf 节 名 ”网 站 物理 路 径 

或 ， 

aspnet_regiis -pd 节 名 -app 网 站 虚拟 目录 

其 中 ,参数 -pdf 表示 对 指定 物理 路 径 的 网 点 的 配置 节 进 行 解密 ,参数 -pd 表示 对 指定 虚拟 
目录 的 网 点 的 配置 节 进 行 解密 。 

【 例 16.3】 对 例 16. 2 的 加 密 结 果 进 行 解密 。 

解 : 其 步骤 如 下 。 

Oa 该 节 的 解密 过 程 如 图 16. 6 所 示 ,表示 成 功 解密 。 

@ 打开 Web. config 文件 ,看 到 一 connectionStrings 二 节 恢 复 成 原来 的 明码 。 
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16.4 ASP.NET 安全 机 制 


16.4.1 ASP.NET 结构 


ASP.N 结构 如 图 16.7 所 示 , 所 有 Web 客户 端 都 通过 IIS(Internet 信息 服务 ) 与 ASP. 
ET 应 用 程序 通信 。IIS 根据 需要 对 请 求 进行 身份 验证 ,然后 找到 请 求 的 资源 (如 ASP. NET 
应 用 程序 ) 。 如 果 客 户 端 已 被 授权 , 则 资源 可 用 。 
当 运 行 ASP.NET 应 用 程序 时 , 它 可 以 使 用 内 置 的 
ASP.NET 安全 功能 。 另 外 ,ASP.NET 应 用 程序 还 可 以 使 Ei 
用 .NET Framework 的 安全 功能 。 


ASP.NET 应 用 程序 “==| IIS | 


16.4.2 ASP.NET 安全 级 别 


.NET Framework 


对 于 主流 的 Web 民有 本 序 * 实现 安全 的 基本 任务 通常 
是 相同 的 。ASP.NET 安全 级 别 如 下 : 


1. 身份 验证 Windows 操 作 系 统 

身份 验证 是 揭示 用 户 标 识 并 判断 标识 真实 性 的 过 程 。 图 16.7 ASP.NET 结构 
身份 验证 就 是 指明 是 谁 在 访问 网 站 。 例 如 , 某 个 人 参加 一 
个 会 议 ， 登记 提供 一 些 证 件 ( 即 表明 身份 的 标识 ) ,一 旦 标识 被 确认 ,他 就 会 得 到 会 议 通行 


证 ,然后 带 着 通行 证 参加 会 议 。 

如 果 访 问 网 站 的 用 户 通 过 了 身份 验证 ,就 会 得 到 一 个 标识 。 在 一 个 特定 的 区 域内 ,该 标识 
都 可 以 被 识别 。 在 ASP.NET 中 有 4 种 身份 验证 的 模式 , 即 Widows 身份 验证 .Forms 身份 验 
证 、.Passpot 身份 验证 和 自 定义 身份 验证 

对 于 每 一 种 身份 验证 ,用 户 都 需要 在 全 录 的 时 候 提供 凭证 ,一 旦 标识 被 核实 ,用 户 就 会 获 
得 一 个 身份 验证 令 牌 ,在 Forms 身份 验证 中 ,整个 令 牌 就 是 FormsAuthenticationTicket( 它 提 
供 对 票证 的 属性 和 值 的 访问 ,这 些 票证 用 于 Forms 身份 验证 对 用 户 进 行 标识 ) ,整个 令 牌 就 放 
在 cookie 中 ,每 次 请 求 资源 的 时 候 令 牌 就 会 提供 用 户 的 标识 信息 。 

2. 授权 

授权 就 是 确定 谁 可 以 对 哪些 资源 操作 和 访问 ? 访问 网 站 的 用 户 是 否 被 授权 使 用 他 所 请 求 
的 资源 ?以 前 面 开 会 为 例子 .授权 就 是 表明 参 会 者 可 以 做 什么 , 当 他 进入 会 议 厅 以 后 会 发 现 有 
很 多 不 同 的 会 议 , 专 家 级 的 ,普通 级 的 ,不 同人 参加 不 同 级 别 的 会 议 ,而 且 有 些 人 可 以 参观 整个 
会 议 厅 , 但 有 些 人 只 能 在 展览 厅 参 观 。 这 就 是 由 权限 的 不 同 而 导致 的 。 
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3. 机 密 性 

当 用 户 使 用 程序 时 ,必须 保证 没有 人 可 以 查看 这 个 用 户 正在 处 理 的 敏感 数据 。 因 此 需要 
对 客户 端 浏览 器 和 服务 器 之 间 的 通道 进行 加 密 , 常 用 的 是 SSL( 安 全 套 接 字 层 ) 技 术 。 例 如 ,用 
户 通过 登录 网 页 提交 了 用 户 名 和 密码 ,就 必须 使 用 SSL 加 密 这 些 信 息 , 要 实现 SSL, 需 要 购买 
一 份 证 书 , 安 装 它 并 正确 配置 IIS。 此 外 ,可 能 还 要 对 后 台数 据 或 客户 端 以 cookie 形式 存储 的 
数据 进行 加 密 。 

4. 完整 性 

最 后 还 要 保证 数据 在 客户 端 和 服务 器 端 传输 过 程 中 没有 被 非 授权 者 修改 过 。 数 字 签 名 提 
供 了 一 个 减轻 这 种 威胁 的 途径 。 


16.4.3 两 种 主要 的 身份 验证 模式 

1. 表单 验证 

表单 验证 是 一 种 常用 的 身份 验证 模式 。 使 用 表单 验证 对 开发 人 员 来 讲 是 一 个 很 有 吸引 力 
的 选择 ,其 原因 如 下 : 

。 开发 人 员 可 以 完全 控制 验证 代码 。 

。 开发 人 员 可 以 完全 控制 登录 表单 的 外 观 。 

。 表单 验证 适用 于 任何 浏览 器 。 

。 它 允 许 开发 人 员 决 定 如何 存 储 用 户 信 息 。 

表单 验证 是 一 个 基于 票据 (ticket) 的 系统 。 这 意味 着 当 一 个 用 户 登录 系统 以 后 ,他 得 到 一 
个 包含 基本 用 户 信 息 的 票据 (ticket)。 这 些 信 息 被 存放 在 加 密 过 的 cookie 里 面 ,这 些 cookie 
和 响应 绑 定 在 一 起 ,因此 每 一 次 后 续 的 请 求 都 会 被 自动 提交 到 服务 器 。 

当 一 个 匿名 用 户 请 求 无 法 访问 的 ASP.NET 的 网 页 时 ,ASP.NET 验证 这 个 表单 验证 票 
据 是 否 有 效 。 如 果 无 效 ,.ASP.NET 自动 将 用 户 转 到 一 个 登录 网 页 。 所 以 在 开发 网 站 时 必须 
创建 一 个 登录 网 页 ,并 且 验 证 由 登录 网 页 提交 的 凭证 。 如 果 用 户 验 证 成 功 , 则 告诉 ASP. NET 
验证 成 功 ( 通 过 调用 FormsAuthentication 类 的 一 个 方法 ) ,运行 库 会 自动 设置 验证 cookie( 实 
际 上 包含 了 票据 ) 并 将 用 户 转 到 原先 请 求 的 页 面 。 通 过 这 个 请 求 ,运行 库 检测 到 验证 cookie 
包含 一 个 有 效 的 票据 ,然后 赋 给 用 户 对 这 个 网 页 的 访问 权限 ,其 流程 如 图 16. 8 所 示 。 

所 以 ,Forms 验证 主要 是 基于 cookie 的 ,就 是 把 用 户 信息 保存 在 cookie 中 ,然后 发 送 到 客 
户 端 ,再 解析 客户 端 发 送 的 cookie 信息 来 进行 验证 。 

例如 ,一 个 用 户 登录 基于 Forms 身份 验证 的 网 站 时 ,其 处 理 步骤 如 下 : 

@ 用 户 请 求 一 个 网 页 (如 Default. aspx) 。 

@ URL 授权 模块 把 用 户 重 定向 到 登录 网 页 (如 Login. aspx), 要 输入 用 户 名 和 密码 等 任 
证 ,通过 提交 给 ASP.NET 网 站 (Web 服务 器 ) 来 审核 ,检查 凭证 是 否 正 确 。 

@ 如 果 赁 证 正确 ,那么 就 会 在 服务 器 端 创建 一 个 身份 验证 票据 ,该 身份 验证 票据 中 含有 
了 经 过 加 密 的 用 户 信息 。 

@ 在 服务 器 端 将 这 个 身份 验证 票据 写 入 cookie 中 ,然后 发 送 到 客户 端 。 

@ 然后 用 户 就 被 重 定向 到 最 初 请 求 的 URL, 即 Default. aspx 网 页 。 

@ 此 时 因为 身份 验证 的 票据 cookie 已 经 存在 于 客户 端的 浏览 器 中 ,在 转向 Default. aspx 
网 页 时 ,实际 上 是 再 次 向 服务 器 端 发 起 了 请 求 , 该 请 求 同 样 需要 经 历 ASP.NET 的 生命 周期 。 

用 户 第 一 次 请 求 Default. aspx 网 页 时 ,该 用 户 根本 没有 提供 任何 表明 身份 的 票据 ,而 第 2 
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客户 请 求 


如 果 IIS 的 验证 通过 ,请 求 被 传送 给 ASP.NET 


登录 表单 收集 用 户 凭证 


验证 用 户 凭证 


验证 通过 ? 


测试 授权 


是 
允许 访问 受 保护 的 资源 


图 16.8 表单 验证 流程 


次 重 定向 到 Default. aspx 网 页 时 ,该 用 户 已 经 登录 了 ,而 且 浏 览 器 中 已 经 有 了 他 的 身份 验证 
票据 的 cookie, 此 时 在 Application_AuthenticateRequest 事件 中 Forms 身份 验证 模块 获取 表 
明 身 份 的 cookie, 然 后 利用 cookie 中 的 信息 填充 Context. User。 

例如 ,以 下 代码 为 基于 表单 身份 验证 配置 网 站 ,指定 传输 来 自 客户 端 登录 信息 的 cookie 
名 称 (401kApp) 以 及 指定 当初 始 身份 验证 失败 时 跳 转 的 登录 网 页 名 称 (login. aspx) ,必须 将 
authorization 节 包 含 在 内 才能 要 求 对 所 有 用 户 进 行 Forms 身份 验证 ,并 拒绝 匿名 用 户 访问 
站 点 ， 


<configuration > 
< System. web > 
<authentication mode = "Forms"> 
< forms name = "401kApp" loginUrl = "/login.aspx"/> 
</authentication > 
<authorization> 
<deny users = "?"/> 
</authorization> 
</system. web > 
</configuration > 


使 用 表单 身份 验证 的 一 种 简便 方法 是 使 用 ASP.NET 成 员 资格 和 ASP.NET 登录 控件 ， 
它们 一 起 提供 了 一 种 只 需 少 量 或 无 需 代 码 就 可 以 收集 、 验 证 和 管理 用 户 赁 据 的 方法 ,将 在 下 一 
章 介绍 。 

2. Windows 验证 

Windows 验证 是 ASP.NET 应 用 程序 的 默认 身份 验证 机 制 , 使 用 Windows 验证 的 好 处 


如 下 : 
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。 对 于 开发 人 员 来 讲 , 它 允许 HS 和 客户 端 浏 览 器 来 处 理 验证 流程 ,不 需要 创建 登录 网 页 
和 检查 数据 库 等 ,几乎 不 需要 进行 多 少 编程 工作 。 
。 人 允许 使 用 现 有 的 Windows 账号 进行 登录 。 
。 为 多 种 类 型 的 应 用 程序 提供 了 一 个 单独 的 验证 模型 ,例如 ,可 以 为 Web 服务 和 ASP. 
NET 应 用 程序 等 使 用 相同 的 验证 模型 ,使 开发 人 员 摆脱 让 身份 信息 在 计算 机 彼此 之 
间 流 动 的 艰苦 工作 。 
。 允许 使 用 身份 模拟 和 Windows 安全 机 制 。 
和 表单 验证 不 同 , Windows 验证 没有 在 ASP.NET 中 内 置 。 相 反 , Windows 验证 将 验证 
的 责任 移交 给 了 IIS。IIS 通过 提供 映射 到 Windows 用 户 账 号 的 凭证 要 求 浏览 器 进行 验证 。 
如 果 用 户 验 证 成 功 ,IIS 允许 这 次 网 页 请 求 , 并 且 将 用 户 和 角色 传递 给 ASP.NET ,这 样 Web 
应 用 程序 就 可 以 用 几乎 和 表单 验证 一 样 的 方式 处 理 这 些 信息 了 。 
IIS 执行 Windows 验证 有 3 种 方式 , 即 基 本 身份 验证 、 摘 要 式 身 份 验证 或 集成 Windows 
身份 验证 。 在 IIS 身份 验证 完成 后 ,ASP.NET 会 使 用 验证 过 的 标识 授权 访问 权限 。 
ASP.NET 中 的 Windows 身份 验证 提供 程序 是 WindowsAuthenticationModule。 
例如 ,以 下 代码 使 用 authentication 配置 为 Windows 验证 : 


< System. web> 
<authentication mode = "Windows"/> 
</system. web> 


16.4.4 ASP.NET 授权 


验证 模块 处 理 完 之 后 就 是 授权 模块 起 作用 了 ,其 实 URL 授权 模块 会 利用 之 前 填充 在 
Context. User 中 的 信息 来 验证 用 户 是 否 被 批准 访问 所 请 求 的 资源 或 者 网 页 。 

在 ASP.NET 中 有 两 种 方式 来 授予 对 给 定 资源 的 访问 权限 。 

1. 文件 授权 

文件 授权 由 FileAuthorizationModule 执行 ,基于 Windows 的 文件 系统 安全 管理 。 它 检 
查 . aspx 或 .asmx 处 理 程序 文件 的 访问 控制 列表 (ACL), 以 确定 用 户 是 否 应 该 具有 对 文件 的 
访问 权限 。ACL 权限 用 于 验证 用 户 的 Windows 标识 (如 果 已 启用 Windows 验证 ) 或 ASP 
NET 进程 的 Windows 标识 。 例 如 ,用 户 请 求 一 个 网 页 ,FileAuthorizationModule 模块 会 检查 
当前 已 验证 过 的 IIS 用 户 是 否 具有 访问 该 . aspx 网 页 的 权限 ,如 果 这 个 用 户 没 有 权限 ,不 会 执 
行 网 页 的 代码 ,用 户 收 到 一 个 “禁止 访问 ”的 信息 。 

文件 授权 只 有 在 使 用 Windows 验证 时 才 会 起 作用 ,对 于 表单 验证 和 自 定义 验证 , 它 不 会 
起 作用 。 

2. URL 授权 

URL 授权 由 UrlAuthorizationModule 执行 , 它 将 用 户 和 角色 映射 到 ASP.NET 应 用 程序 
中 的 URL。 这 个 模块 可 用 于 有 选择 地 允许 或 拒绝 特定 用 户 或 角色 对 应 用 程序 的 任意 部 分 ( 通 
常 为 目录 ) 的 访问 权限 。 

通过 URL 授权 可 以 显 式 地 允许 或 拒绝 某 个 用 户 名 或 角色 对 特定 目录 的 访问 权限 ,为 此 
需要 在 该 目录 的 配置 文件 中 创建 一 个 authorization 节 。 若 要 启用 URL 授权 ,需要 在 配置 文 
件 的 authorization 节 中 的 allow 或 deny 元 素 中 指定 一 个 用 户 或 角色 列表 。 为 目录 建立 的 权 
限 也 会 应 用 到 其 子 目录 ,除非 子 目 录 中 的 配置 文件 重 写 这 些 权限 。 


449 


450 
P.NET 4.5 动态 网 站 设计 教程 一 一 基于 C# 5. 0 十 SQL Server 2012 


例如 ,以 下 代码 对 Kim 用 户 和 Admins 角色 的 成 员 授予 访问 权限 ,对 John 标识 (除非 
Admins 角色 中 包含 John 标识 ) 和 所 有 匿名 用 户 拒绝 访问 权限 : 


<authorization> 
<allow users = "Kim"/> 
<allow roles = "Admins"/> 
<deny users = "John"/> 
<deny users= "?"/> 
</authorization > 


练习 题 16 


. 简 述 Web. config 配置 文件 的 作用 。 

. 简 述 Web. config 配置 文件 中 connectionSettings 节 的 设置 和 使 用 方法 。 
. 简 述 Web. config 配置 文件 中 appSettings 节 的 设置 和 使 用 方法 。 

. 简 述 Web. config 配置 文件 的 解密 和 解密 过 程 。 


上 机 实验 题 16 
在 ch16 网 站 中 修改 Web. config 文件 ,配置 logon. aspx 网 页 为 ASP. NET 在 找 不 到 包含 


请 求 内 容 的 身份 验证 cookie 的 情况 下 进行 重 定向 时 所 使 用 的 URL, 并 拒绝 未 通过 身份 验证 的 
用 户 访问 该 应 用 程序 中 的 资源 。 


一 


成 员 资 格 和 角色 管理 军 上 7 束 


表单 验证 解决 了 为 ASP.NET 程序 实现 安全 的 自 定 义 登录 表单 的 验证 问 
题 , 但 是 表单 验证 只 提供 了 验证 用 户 的 架构 ,开发 人 员 必 须 自 己 实现 登录 表 
单 以 及 与 底层 的 凭证 存储 之 间 的 通信 ,如 添加 用 户 、 删 除 用 户 、 重 设 密码 等 。 
用 户 权限 管理 涉及 角色 的 概念 ,角色 可 以 被 看 成 是 具有 特定 权限 的 用 户 集 
合 。ASP.NET 成 员 资格 和 角色 管理 属于 网 站 安全 性 管理 。 本 章 介 绍 成 员 资 
格 和 角色 管理 的 一 些 基本 概念 及 其 管理 方法 。 

本 章 学 习 要 点 : 

回 了 解 成 员 资格 的 概念 以 及 创建 成 员 资格 的 过 程 。 

回 了 解 角色 的 概念 以 及 创建 角色 的 过 程 。 

回 掌 握 成 员 资 格 和 角色 配置 方法 。 


17.1 成 员 资格 概述 


17.1.1 ASP.NET 成 员 资格 体系 结构 


ASP.NET 成 员 资 格 (membership) 的 主要 功能 是 管理 系统 的 用 户 ,提供 
了 一 种 验证 和 存储 用 户 凭据 的 内 置 方法 ,以 保证 只 有 合法 的 登录 用 户 才能 
使 用 网 站 系统 的 某 些 网 页 和 功能 。 开 发 人 员 可 以 将 ASP.NET 成 员 资 格 与 
表单 验证 或 ASP.NET 登录 控件 一 起 使 用 ,以 创建 一 个 完整 的 用 户 身 份 验 
证 系统 。 
由 于 所 有 用 户 网 站 登录 操作 是 相似 的 .所 以 ASP.NET 成 员 资 格 提供 了 一 
个 通用 的 安全 的 用 户 管理 功能 。 归 纳 起 来 .ASP.NET 成 员 资 格 支 持 以 下 功能 : 
。 创建 新 用 户 和 密码 。 
。 将 成 员 资格 信息 (用 户 名 、 密 码 和 支持 数据 ) 存 储 在 SQL Server 或 其 他 
。 对 访问 站 点 的 用 户 进行 身份 验证 ,可 以 以 编程 方式 验证 用 户 , 也 可 以 使 
用 ASP.NET 登录 控件 创建 一 个 只 需 很 少 代 码 或 无 需 代 码 的 完整 身份 
验证 系统 。 
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。 管理 密码 ,包括 创建 .更 改 和 重 置 密码 。 根 据 开 发 人 员 选 择 的 成 员 资格 选项 不 同 ,成 员 

资格 系统 还 可 以 提供 一 个 使 用 用 户 提供 的 问题 和 答案 的 自动 密码 重 置 系统 。 

。 公开 经 过 身份 验证 的 用 户 的 唯一 标识 ,可 以 在 自己 的 应 用 程序 中 使 用 该 标识 ,也 可 以 

将 该 标识 与 ASP.NET 个 性 化 设置 和 角色 管理 (授权 ) 系 统 集成 。 

。 指定 自 定义 成 员 资 格 提供 程序 ,开发 人 员 可 以 改 为 用 自己 的 代码 管理 成 员 资格 及 在 自 

定义 数据 存储 区 中 维护 成 员 资格 数据 。 

成 员 资 格 体系 结构 如 图 17. 1 所 示 ,最 底层 是 成 员 资格 数据 层 , 用 于 存放 用 户 的 数据 ,包括 
SQL Server 数据 库 以 及 其 他 数据 源 。 成 员 资格 提供 程序 层 (Membership Providers) 从 中 取出 
数据 , 交 给 上 层 的 成 员 资 格 API 层 , 成 员 资 格 API 层 用 其 中 两 个 核心 类 Membership 和 
MembershipUser 来 管理 这 些 用 户 数 据 , 并 且 可 以 交 由 网 页 中 的 一 些 用 户 管理 控件 (登录 控件 
层 ) 使 用 。 从 中 看 到 ,ASP.NET 通过 内 置 成 员 资格 API 与 SQL Server Express 数据 库 有 效 
结合 ,将 大 量 复杂 烦琐 的 身份 验证 代码 封装 为 不 同 的 类 库 , 为 开发 用 户 权限 管理 功能 提供 了 
方便 。 成 员 资格 体系 结构 采用 分 层 的 架构 ,每 一 层 都 可 以 被 独立 地 替换 掉 。 


登录 控件 层 | Login [oginstatus LoginView 其 他 登录 控件 
成 员 资格 API 层 Membership 类 MembershipUser 类 | 


成 员 资格 提供 程序 层 SqlMembershipProvider 其 他 成 员 提 供 程序 


个 


成 员 资格 数据 层 EE 其 他 数据 库 


图 17.1 成 员 资格 体系 结构 


17.1.2 配置 成 员 资格 的 过 程 


若 要 使 用 成 员 资格 ,必须 首先 为 网 站 配置 成 员 资格 ,其 主要 过 程 如 下 : 

@ 指定 要 使 用 的 成 员 资格 提供 程序 .成员 资格 提供 程序 与 存储 成 员 资格 信息 (如 用 户 信 
息 等 ) 的 数据 库 类 型 是 密 不 可 分 的 。 默 认 提 供 程序 使 用 SQL Server 数据 库 。 用 户 还 可 以 选择 
使 用 活动 目录 存储 成 员 资格 信息 ,或 者 可 以 指定 自 定义 提供 程序 。 

@ 将 应 用 程序 配置 为 使 用 表单 身份 验证 ,通常 指定 应 用 程序 中 的 某 些 网 页 或 目录 受到 保 
护 , 并 只 能 由 经 过 身份 验证 的 用 户 访问 。 

@ 为 成 员 资格 定义 用 户 账户 ,可 以 通过 多 种 方式 实现 ,如 使 用 网 站 管理 工具 或 者 创建 新 
用 户 ? 的 ASP.NET 网 页 并 使 用 相应 的 成 员 资格 函数 在 成 员 资格 系统 中 创建 新 用 户 。 

在 为 网 站 配置 好 成 员 资格 后 ,就 可 以 使 用 成 员 资格 对 应 用 程序 中 的 用 户 进行 身份 验证 了 。 
在 大 多 数 情况 下 ,开发 人 员 需 要 提供 一 个 登录 网 页 ,可 以 使 用 TextBox 等 控件 手动 创建 登录 
网 页 ,也 可 以 使 用 ASP.NET 登录 控件 。 由 于 已 将 应 用 程序 配置 为 使 用 表单 身份 验证 ,因此 在 
未 经 验证 的 用 户 请 求 一 个 受 保护 的 网 页 时 ,ASP.NET 将 自动 显示 登录 网 页 。 
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下 面 按照 成 员 资 格 体系 结 构 中 从 底层 到 项 层 的 顺序 介绍 各 部 分 内 容 。 


17.2 建立 成 员 资 格 数 据 


首先 要 建立 成 员 资 格 数据 ,ASP.NET 提供 了 建立 成 员 资格 数据 的 专用 工具 , 称 之 为 注册 
工具 。ASP.NET SQL Server 注册 工具 aspnet_regsql. exe 用 于 创建 供 ASP.NET 中 的 SQL 
Server 提供 程序 使 用 的 SQL Server 数据 库 ,或 者 用 于 在 现 有 数据 库 中 添加 或 移 除 选 项 。 
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aspnet_regsql. exe 是 一 个 可 执行 程序 ,可 以 使 用 它 来 建立 成 员 资格 数据 。 执 行 aspnet 


regsql. exe 可 以 带 多 个 参数 ,如 参数 -? 表示 在 命令 窗口 中 显示 帮助 文本 ,-E 表示 使 用 当前 登 


录用 户 的 Windows 凭据 进行 身份 验证 ,等 等 。 另 外 ,可 以 不 带 任何 命令 行 参数 运行 aspnet 


regsql. exe, 以 运行 一 个 向 导 完成 如 下 过 程 的 向 导 : 为 SQL Server 安装 指定 连接 信息 ,并 为 成 
员 资格 .角色 管理 器 ,配置 文件 .Web 部 件 个 性 化 设置 及 运行 状况 监视 等 功能 安装 或 移 除数 据 


库 元 素 。 
【 例 17. 1】 在 Stud 数据 库 中 建立 成 员 资格 数据 表 。 
解 : 其 步骤 如 下 。 


OO 在 Windows 中 单 击 “开始 ”按钮 ,选择 “所 有 程序 |Microsoft Visual Studio 2012|Visual 
Studio Tools|VS2012 x86 本 机 工具 命令 提示 ”命令 ,然后 输入 aspnet_regsql 命令 即 可 启动 
aspnet_regiis 工具 。 

@ 在 出 现 的 欢迎 使 用 界面 中 单 击 “ 下 一 步 ”按钮 。 

@ 出 现 如 图 17. 2 所 示 的 “选择 安装 选项 ”对 话 框 , 单 击 “ 下 一 步 ” 按 钮 。 


要 执行 什么 数据 库 任务 ?7 
图 为 应 用 祥 厚 服务 配 次 SQL Server 四) 
此 选项 运行 的 肢 本 可 创 汗 新 教 据 库 或 配置 现 有 数据 库 ， 以 存 税 了 eT 成 员 资格 、 本 置 文 
件 、 角 色 管 理 、 个 性 化 设置 以 及 SQL Web 本 人 
个 移 除 现 有 数据 库 中 的 应 用 祥 厚 服 秀 信息 (E) 


此 选项 可 移 除 教 据 库 中 有 关 _ASP. WET 成 员 资格 、 配 置 文件 、 角 色 管理 、 个 性 化 设置 以 及 SQL 
Yeb 事件 提供 程序 的 信息 。 注意 : 此 进程 无 法 赂 消 * 


注意 : | 
若 要 为 会 话 杖 态 或 Ge dd 请 在 命令 行 中 运行 aspnet_reesql。 有 
关 命 令 行 选项 的 帮助 


图 17.2 “选择 安装 选项 ?对 话 框 


@ 出 现 “ 选 择 服 务 器 和 数据 库 ” 对 话 框 ,设置 服务 器 为 “YLCB-PC”、 用 户 名 为 “sa”、 密 码 为 
“12345”, 选 择 数据 库 为 “Stud”, 如 图 17. 3 所 示 , 单 击 下 一 步 ” 按 钮 。 

@ 在 出 现 的 确认 界面 中 单 击 “ 下 一 步 ” 按 钮 。 

@ 单 击 “ 完 成 "按钮 。 

此 时 再 进入 SQL Server 2012 系统 ,打开 Stud 数据 库 . 看 到 经 过 前 面 的 操作 后 新 建 了 一 
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系列 的 表 , 如 图 17.4 所 示 , 这 些 表 的 功能 如 下 。 


指定 S9L Server 名 称 、 要 创建 或 移 除 的 教 据 库 的 名 称 ， 以 及 连接 数据 库 时 要 使 用 的 赁 据 * 
注意 - 赁 所 必须 标识 一 个 具有 创建 或 移 队 数据 库 的 权限 的 用 户 帐户 。 


服务 器 (S); LCB-PC\SQLEXPRESS 
口 Windows 身份 验证 (人 
回 SQL Server 身份 验证 (9) 
用 户 名 0: sa 
密 吗 (内 :re 
数据 库 (D); [Stud 


[aa [未 | 世 


图 17.3 “选择 服务 器 和 数据 库 ” 对 话 框 


型 表 理 了 司 当 
日 图 !C8-PO\SQLEXPRESS (SQL Server 11.0.2100 - sa) 
日 向 数 损 库 
轩 加 系统 数据 库 
@ Ubray 
田 国 School 
日 国 sud 
田 筷 数据 库 关系 图 
日 息 事 
田 国 系统 表 
田 国 FleTables 
田口 加 pphicenlions 
田 回 dbo.aspnet_Membership 
田 回 dbo.aspnet_Paths 
国 日 dbo.aspnet_PersonalizationAllUsers 
@ 9 dbo.aspnet PersonalizationPerUser 
国 dbo.aspnet_Profile 
回 dboaspnet Roles 
回 回 dbo.aspnet SchemaVersions 
田 国 dbo.aspnet Users 
田 回 dboaspnet UsersinRoles 
田 国 dboaspnet WebEvent_Events 
国 国 dbo.score 
田 国 dbo.student 


图 17.4 Stud 数据 库 中 建立 的 成 员 资 格 数据 表 


aspnet_Applications: 存放 数据 库 所 涉及 应 用 程序 的 有 关 信息 。 

aspnet_Membership: 存放 与 用 户 相关 的 信息 ,例如 用 户 登 录 密 码 、 创 建 时 间 。 
aspnet_Paths: 存放 应 用 程序 和 目录 路 径 的 对 应 关系 数据 。 
aspnet_PersonalizationAllUsers: 存放 针对 所 有 用 户 的 Web 部 件 个 性 化 设置 信息 。 
aspnet_PersonalizationPerUser: 存放 针对 每 个 特定 用 户 的 Web 部 件 个 性 化 设置 


信息 。 
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aspnet_Profile: 存放 用 户 配 置 数据 。 

。 aspnet_Roles: 存放 角色 信息 。 

。 aspnet_SchemaVersions: 存放 用 户 配置 信息 支持 的 模式 。 

。 aspnet_Users: 存放 用 户 基本 信息 。 

。 aspnet_UsersInRoles: 存放 用 户 和 角色 的 关系 数据 。 

。 aspnet_WebEvent_Events: 存放 Web 事件 的 相关 信息 。 

上 述 表 是 用 户 通 过 操作 由 系统 自动 创建 的 ,还 包括 许多 存储 过 程 等 ,用 户 不 必修 改 这 些 
内 容 。 


17.3 成 员 资 格 提供 程序 


ASP.NET 成 员 资格 主要 由 内 置 成 员 资格 提供 程序 组 成 ,这 些 提 供 程序 与 数据 源 进 行 通 
信 。MembershipProvider 类 提供 了 这 样 的 协定 ,以 便 ASP.NET 使 用 自 定义 成 员 资 格 提供 程 
序 来 实现 提供 成 员 资格 服务 。 


17.3.1 SqlMembershipProvider 提供 程序 


SqlMembershipProvider 类 是 从 MembershipProvider 类 派生 的 ,位 于 System. Web. 
Security 命名 空间 。 

提供 程序 用 于 管理 SQL Server 数据 库 中 ASP.NET 应 用 程序 的 成 员 资 格 信息 存储 ,包括 
SQL Server 数据 库 中 存储 的 用 户 名 和 密码 等 .该 类 供 Membership 和 MembershipUser 类 使 
用 ,为 使 用 SQL Server 数据 库 的 ASP.NET 应 用 程序 提供 成 员 资 格 服务 。 

说 明 : 在 计算 机 以 默认 实例 名 安装 了 SQL Server Express 并 启用 了 用 户 实例 化 的 情况 
下 ,在 应 用 程序 首次 运行 时 ,SqlMembershipProvider 对 象 将 在 网 站 的 App_Data 目录 创建 一 
个 名 为 aspnetdb 的 数据 库 , 其 中 包含 与 图 17.4 相同 的 成 员 资 格 数据 表 , 这 样 开发 人 员 不 需要 
采用 17.2 节 的 方法 建立 成 员 资格 数据 。 

SqlMembershipProvider 类 的 主要 属性 如 表 17. 1 所 示 , 其 主要 方法 如 表 17.2 所 示 。 

表 17.1 SqlMembershipProvider 类 的 主要 属性 及 其 说 明 


属 性 说 明 

ApplicationName 获取 或 设置 要 存储 和 检索 其 成 员 资格 信息 的 应 用 程序 的 名 称 

EnablePasswordReset 获取 一 个 值 ,指示 SQL Server 成 员 资格 提供 程序 是 否 配置 为 允 
许 用 户 重 置 其 密码 

EnablePasswordRetrieval 获取 一 个 值 ,指示 SQL Server 成 员 资 格 提供 程序 是 否 配 置 为 允 
许 用 户 检 索 其 密码 

MaxInvalidPasswordAttempts 获取 锁定 成 员 资格 用 户 前 允许 的 无 效 密码 或 无 效 密码 提示 问题 
答案 尝试 次 数 

MinRequiredNonAlphanumericCharacters 获取 有 效 密码 中 必须 包含 的 最 少 特殊 字符 数 

MinRequiredPasswordLength 获取 密码 所 要 求 的 最 小 长 度 

Name 获得 一 个 友好 名 称 , 用 于 在 配置 过 程 中 引用 提供 程序 

PasswordAttempt Window 获取 时 间 长 度 , 在 该 时 间 间 隔 内 对 提供 有 效 密码 或 密码 答案 的 


连续 失败 尝试 次 数 进行 跟踪 
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续 表 
属 性 说 明 
PasswordFormat 获取 一 个 值 ,表示 用 于 在 SQL Server 成 员 资格 数据 库 中 存储 密 
码 的 格式 ,可 以 取 如 下 值 。 
O@ Clear: 密码 未 加 密 。 
@ Encrypted: 密码 加 密 。 
@ Hashed: 密码 单 向 加 密 
PasswordStrengthRegularExpression 获取 用 于 计算 密码 的 正则 表达 式 
RequiresQuestionAndAnswer 获取 一 个 值 , 指 示 SQL Server 成 员 资 格 提供 程序 是 否 配置 为 要 
求 用 户 在 进行 密码 重 置 和 检索 时 回答 密码 提示 问题 
RequiresUniqueEmail 获取 一 个 值 , 指 示 SQL Server 成 员 资 格 提供 程序 是 否 配置 为 要 
求 每 个 用 户 名 具有 唯一 的 电子 邮件 地 址 
表 17.2 SqlMembershipProvider 类 的 主要 方法 及 其 说 明 
方 法 说 明 
ChangePassword 修改 用 户 密码 
ChangePasswordQuestionAndAnswer 更 新 SQL Server 成 员 资 格 数据 库 中 用 户 的 密码 提示 问题 和 答案 
CreateUser 向 SQL Server 成 员 资格 数据 库 添 加 一 个 新 用 户 
DecryptPassword 解密 已 加 密 的 密码 
DeleteUser 从 SQL Server 成 员 资格 数据 库 删除 用 户 的 成 员 资格 信息 
EncryptPassword 对 密码 进行 加 密 
FindUsersByEmail 返回 成 员 资格 用 户 的 集合 ,其 中 用 户 的 电子 邮件 地 址 字段 包含 指 
定 的 电子 邮件 地 址 
FindUsersByName 获取 一 个 成 员 资格 用 户 的 集合 ,其 中 的 用 户 名 包含 要 匹配 的 指定 
用 户 名 
GeneratePassword 生成 长 度 至 少 为 14 个 字符 的 随机 密码 
GetAllUsers 获取 SQL Server 成 员 资 格 数据 库 中 所 有 用 户 的 集合 
GetNumberOfUsersOnline 返回 当前 访问 该 应 用 程序 的 用 户 数 
GetPassword 从 SQL Server 成 员 资 格 数据 库 返 回 指定 用 户 名 的 密码 
GetUser 从 数据 源 获 取 成 员 资 格 用 户 的 信息 
GetUserNameByEmail 获取 与 指定 的 电子 邮件 地 址 关联 的 用 户 名 
ResetPassword 将 用 户 密码 重 置 为 一 个 自动 生成 的 新 密码 
UpdateUser 更 新 SQL Server 成 员 资 格 数据 库 中 用 户 的 信息 
ValidateUser 验证 SQL Server 成 员 资 格 数据 库 中 是 否 存在 指定 的 用 户 名 和 和 密码 


在 默认 情况 下 ,ASP.NET 成 员 资格 可 支持 所 有 的 ASP.NET 应 用 程序 。 默 认 成 员 资 格 
提供 程序 为 SqlMembershipProvider, 并 在 计算 机 配置 中 以 名 称 AspNetSqlProvider 指定 ， 
SqlMembershipProvider 的 默认 实例 配置 为 连接 到 Microsoft SQL Server 的 一 个 本 地 实例 ,可 
以 从 Machine. config 文件 中 的 以 下 代码 看 到 这 种 配置 : 


< connectionStrings > 
<add name = "LocalSqlServer" 
connectionString = "data source= . \SQLEXPRESS; 
Integrated Security = SSPI; 
AttachDBFilename = |DataDirectory|aspnetdb. mdf; 
User Instance = true" providerName = "System.Data. SqlClient"/> 
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</connectionStrings > 
<membership> 
<providers> 
<add name = "AspNetSqlMember shipProvider" 
type = "System. Web. Security. SqlMembershipProvider, System. Web, 

Version = 4.0.0.0, Culture= neutral, PublicKeyToken= b03f5f7f11d50a3a" 
connectionStringName = "LocalSqlServer" enablePasswordRetrieval = "false" 
enablePasswordReset = "true" requiresQuestionAndAnswer = "true" 
applicationName = "/" requiresUniqueEmail = "false" passwordFormat = "Hashed" 
maxInval idPasswordAttempts = "5" minRequiredPasswordLength = "7" 
minRequiredNonalphanumericCharacters = "1" passwordAttemptWindow = "10" 
passwordStrengthRegularExpression = ""/> 

</providers > 
</membership > 


其 中 定义 一 个 名 称 为 AspNetSqlMembershipProvider 的 默认 SqlMembershipProvider 实 
例 ,该 实例 连接 到 本 地 计算 机 上 的 默认 SQL Server Express 实例 。 网 站 中 的 Web. config 可 
以 自动 继承 该 配置 。 也 就 是 说 ,如 果 SQL Server Express 以 默认 实例 名 安装 , 则 可 使 用 提供 
程序 的 此 实例 ,否则 ,可 在 ASP.NET 网 站 的 Web. config 文件 中 配置 自己 的 SqlMember- 
shipProvider 提供 程序 。 

例如 ,下 面 的 Web. config 文件 中 system. web 节 的 membership 元 素 配 置 元 素 , 它 指定 应 
用 程序 使 用 SqlMembershipProvider 类 的 实例 提供 成 员 资 格 服务 ,并 将 passwordStrength- 
RegularExpression 特性 设置 为 验证 密码 是 否 满足 以 下 条 件 的 正则 表达 式 : 至 少 为 7 个 字符 ; 
至 少 包含 一 个 数字 ; 至 少 包含 一 个 特殊 字符 ( 非 字 母 数字 字符 ) 。 如 果 密 码 不 符合 这 些 条 件 ， 
成 员 资格 提供 程序 将 不 接受 此 密码 。 


<membership defaultProvider = "SqlProvider" userIsOnlineTimeWindow = "20"> 
<providers> 
<add name = "SqlProvider" 
type = "System. Web. Security. SqlMembershipProvider" 
connectionStringName = "MySqlServer" 
requiresQuestionAndAnswer = "true" 
passwordStrengthRegularExpression= 
"@\"(?=.{6,1)(?=(.*\d){1,})(?=(. *\W){1,})" /> 
</providers> 
</membership> 


17.3.2 配置 自己 的 SqlMembershipProvider 提供 程序 


如 果 要 配置 自己 的 SqlMembershipProvider 提供 程序 ,采用 的 方法 是 先 配置 ASP. NET 
连接 字符 串 , 再 定制 自己 的 SqljMembershipProvider 提供 程序 .定制 后 者 使 用 membership 
元 素 。 

membership 元 素 使 用 ASP.NET 成 员 资 格 配置 用 于 对 用 户 账 户 进行 管理 和 身份 验证 的 
参数 ,其 主要 的 属性 是 defaultProvider, 它 指 定 默认 成 员 资 格 提供 程序 的 名 称 , 默 认 值 为 
AspNetSqlProvider( 其 类 型 为 AspNetSqlMembershipProvider) 。 

membership 元 素 的 子 元 素 有 providers, 它 是 定义 成 员 资格 提供 程序 的 集合 。 

【 例 17.2】 为 例 17. 1 创建 的 成 员 资格 数据 配置 自己 的 SqlMembershipProvider 提供 
程序 。 
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解 : 其 步骤 如 下 。 
@ 以 “D:\ASP.NET\ch17” 为 路 径 创建 一 个 “文件 系统 ”类 型 的 空 网 站 ch17。 
@ 打开 网 站 下 的 Web. config 文件 ,修改 代码 如 下 : 


<configuration> 
<connectionStrings> 
<add name = "MYMembershipConnString” 
connectionString = "Data Source = LCB - PC\SQLEXPRESS; 
Initial Catalog = Stud;User ID = sa;Password= 12345" /> 
</connectionStrings > 
<system.web> 
<compilation debug = "true" /> 
<authentication mode = "Forms"> 
< forms name = ". ASPXFORMSAUTH" /> 
</authentication> 
< membership defaultProvider = "SqlProvider" > 
<providers> 
< remove name = " AspNet SqlProvider" /> 
<add name = "SqlProvider" 
type = "System. Web. Security. SqglMember shipProvider" 
connectionStringName = "MyMembershipConnString" 
enablePasswordRetrieval = "false" 
enablePasswordReset = " true” 
requiresQuestionAndAnswer = "true" 
passwordFormat = "Hashed" 
applicationName = "/" /> 
</providers> 
</membership> 
</system. web > 
</configuration > 


其 中 配置 连接 字符 串 为 MyMembershipConnString ,定制 的 SqlMembershipProvider 提 
供 程序 为 SqlProvider, 对 应 的 连接 字符 串 名 为 MyMembershipConnString。 这 样 ,用 户 的 信息 
就 会 存储 在 Stud 数据 库 中 ,而 不 是 默认 的 aspnetdb 数据 库 中 。 

forms 的 name 属性 设置 为 ". ASPXFORMSAUTH"”, 这 是 为 包含 身份 验证 票证 的 cookie 
的 名 称 设置 的 后 绥 。 

如 果 要 进一步 自 定义 成 员 资格 提供 程序 ,需要 继承 MembershipProvider 类 ,这 里 不 再 
介绍 。 


17.4 成 员 资 格 API 


成 员 资 格 API 即 成 员 资 格 应 用 程序 接口 , ASP.NET 提供 的 成 员 资 格 API 类 有 
Membership .MembershipUser 和 MembershipCreateStatus 类 等 。 


17.4.1 Membership 类 
Membership 类 提供 常规 成 员 资格 功能 , 它 提 供 了 一 系列 的 静态 方法 与 属性 ,用 于 完成 创 
建 用 户 ,管理 密码 以 及 身份 验证 的 功能 。 


Membership 类 的 常用 属性 及 说 明 如 表 17. 3 所 示 ,其 常用 方法 及 说 明 如 表 17. 4 所 示 , 其 
常用 事件 及 说 明 如 表 17. 5 所 示 。 
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表 17.3 Membership 类 的 常用 属性 及 其 说 明 


属 性 说 明 

ApplicationName 获取 或 设置 应 用 程序 的 名 称 

EnablePasswordReset 获取 一 个 值 ,指示 当前 成 员 资 格 提供 程序 是 否 配置 为 允许 用 户 
重 置 其 密码 

EnablePasswordRetrieval 获取 一 个 值 ,指示 当前 成 员 资 格 提供 程序 是 否 配置 为 允许 用 户 
检索 其 密码 

HashAlgorithmType 用 于 哈 希 密码 的 算法 的 标识 符 

MaxInvalidPasswordAttempts 获取 锁定 成 员 资格 用 户 前 允许 的 无 效 密码 或 无 效 密码 提示 问题 
答案 尝试 次 数 


MinRequiredNonAlphanumericCharacters 获取 有 效 密码 中 必须 包含 的 最 少 特殊 字符 数 
MinRequiredPasswordLength 获取 密码 所 要 求 的 最 小 长 度 
PasswordStrengthRegularExpression 获取 用 于 计算 密码 的 正则 表达 式 


Provider 获取 对 应 用 程序 的 默认 成 员 资格 提供 程序 的 引用 
RequiresQuestionAndAnswer 获取 一 个 值 , 该 值 指示 默认 成 员 资格 提供 程序 是 否 要 求 用 户 在 
进行 密码 重 置 和 检索 时 回答 密码 提示 问题 
表 17.4 Membership 类 的 常用 方法 及 其 说 明 
方 法 说 明 


CreateUser 
DeleteUser 
FindUsersByEmail 


FindUsersByName 
GeneratePassword 
GetAllUsers 
GetNumberOfUsersOnline 
GetUser 
GetUserNameByEmail 
UpdateUser 

ValidateUser 


事 件 


将 新 用 户 添加 到 数据 存储 区 

从 数据 库 中 删除 一 个 用 户 

获取 一 个 成 员 资格 用 户 的 集合 ,其 中 的 电子 邮件 地 址 包含 要 匹配 的 指定 电子 
邮件 地 址 

获取 一 个 成 员 资 格 用 户 的 集合 ,其 中 的 用 户 名 包含 要 匹配 的 指定 用 户 名 
生成 指定 长 度 的 随机 密码 

获取 数据 库 中 用 户 的 集合 

获取 当前 访问 应 用 程序 的 用 户 数 

从 数据 源 获取 成 员 资 格 用 户 的 信息 

获取 一 个 用 户 名 ,其 中 该 用 户 的 电子 邮件 地 址 与 指定 的 电子 邮件 地 址 匹配 
用 指定 用 户 的 信息 更 新 数据 库 

验证 提供 的 用 户 名 和 密码 是 有 效 的 


表 17.5 Membership 类 的 常用 事件 及 其 说 明 
说 明 


ValidatingPassword 


在 创建 用 户 ,更改 密码 或 重 置 密码 时 发 生 


说 明 : Membership 类 是 一 个 静态 类 ,不 能 由 它 派生 对 象 ,可 以 通过 “Membership. 成 员 ” 


来 使 用 其 成 员 。 


Membership 类 依赖 于 成 员 资 格 提 供 程 序 与 数据 源 通信 。 在 例 17.2 中 已 经 配置 好 了 相关 
的 成 员 资 格 提 供 程序 SqlProvider 与 数据 源 Stud。 

在 网 页 中 可 以 直接 使 用 MemberShip 的 一 系列 静态 方法 来 管理 用 户 , 如 创建 新 用 户 、 删 除 
一 个 用 户 、 更 新 用 户 信 息 等 。 例 如 : 


Member ship. CreateUser( "username", "password"); 
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Member ship. DeleteUser( "username" ); 


这 就 使 开发 人 员 很 方便 地 在 网 页 中 集成 用 户 管理 的 功能 (如 在 页 面 上 提供 注册 新 用 户 账 


号 的 功能 )。 


17.4.2 MembershipUser 类 


MemberShipUser 类 代表 单个 的 用 户 权 限 信 息 ,提供 有 关 特 定 用 户 的 信息 ,如 获取 密码 和 
密码 问题 更改 密码 ,确定 用 户 是 否 联 机 确定 用 户 是 否 已 经 过 验证 ,返回 最 后 一 次 活动 、 登 录 
和 密码 更 改 的 日 期 .取消 对 用 户 的 锁定 。 

MembershipUser 类 的 常用 属性 及 说 明 如 表 17. 6 所 示 , 其 常用 方法 及 说 明 如 表 17. 7 


所 示 。 
表 17.6 MembershipUser 类 的 常用 属性 及 其 说 明 
属 性 说 明 
Comment 获取 或 设置 成 员 资格 用 户 的 特定 于 应 用 程序 的 信息 


CreationDate 

Email 

JsApproved 

JsLockedOut 
LastActivityDate 
LastLockoutDate 
LastLoginDate 
LastPasswordChangedDate 
PasswordQuestion 


ProviderName 


ProviderUserKey 


UserName 


方 ”法 


获取 将 用 户 添 加 到 成 员 资格 数据 存储 区 的 日 期 和 时 间 

获取 或 设置 成 员 资格 用 户 的 电子 邮件 地 址 

获取 或 设置 一 个 值 ,表示 是 否 可 以 对 成 员 资格 用 户 进行 身份 验证 

获取 一 个 值 , 该 值 指示 成 员 资格 用 户 是 否 因 被 锁定 而 无 法 进行 验证 

获取 或 设置 成 员 资格 用 户 上 次 进行 身份 验证 或 访问 应 用 程序 的 日 期 和 时 间 
获取 最 近 一 次 锁定 成 员 资格 用 户 的 日 期 和 时 间 

获取 或 设置 用 户 上 次 进行 身份 验证 的 日 期 和 时 间 

获取 上 次 更 新 成 员 资格 用 户 的 密码 的 日 期 和 时 间 

获取 成 员 资格 用 户 的 密码 提示 问题 

获取 成 员 资格 提供 程序 的 名 称 , 该 提供 程序 存储 并 检索 成 员 资格 用 户 的 用 户 
信息 

从 用 户 的 成 员 资格 数据 源 获取 用 户 标 识 符 

获取 成 员 资格 用 户 的 登录 名 


表 17.7 MembershipUser 类 的 常用 方法 及 其 说 明 
说 明 


ChangePassword 


更 新 成 员 资格 数据 存储 区 中 成 员 资格 用 户 的 密码 


ChangePasswordQuestionAndAnswer ”更 新 成 员 资格 数据 存储 区 中 成 员 资格 用 户 的 密码 提示 问题 和 密码 


GetPassword 
ResetPassword 


UnlockUser 


提示 问题 答案 

从 成 员 资格 数据 存储 区 获取 成 员 资格 用 户 的 密码 
将 用 户 密码 重 置 为 一 个 自动 生成 的 新 密码 
清除 用 户 的 锁定 状态 以 便 可 以 验证 成 员 资格 用 户 


MembershipUser 对 象 可 由 Membership 对 象 的 GetUser 和 CreateUser 方法 返回 。 例 
如 ,以 下 代码 查找 管理 员 用 户 sa ,并且 输出 其 登录 信息 : 


MembershipUser user = Membership. GetUser("sa"); 


if(user!= nul1) 


Response. Write(" 上 次 登录 时 间 : "+ user.LastLoginDate. ToString()); 


461 
第 17 章 成员 资格 和 角色 管 圈 
17.4.3 MembershipCreateStatus 类 


MembershipCreateStatus 类 提供 描述 性 值 ,用 于 描述 创建 一 个 新 成 员 资格 用 户 时 是 成 功 
还 是 失败 ,也 就 是 说 MembershipCreateStatus 类 描述 CreateUser 操作 的 结果 ,其 描述 性 值 及 
说 明 如 表 17. 8 所 示 。 

表 17.8 MembershipCreateStatus 类 提供 的 描述 性 值 及 其 说 明 


成 员 名 称 说 明 
Success 创建 用 户 成 功 
InvalidUserName 在 数据 库 中 未 找到 用 户 名 
InvalidPassword 密码 的 格式 设置 不 正确 
InvalidQuestion 密码 提示 问题 的 格式 设置 不 正确 
JnvalidAnswer 密码 提示 问题 答案 的 格式 设置 不 正确 
InvalidEmail 电子 邮件 地 址 的 格式 设置 不 正确 
DuplicateUserName 用 户 名 已 存在 于 应 用 程序 的 数据 库 中 
DuplicateEmail 电子 邮件 地 址 已 存在 于 应 用 程序 的 数据 库 中 
UserRejected 因为 提供 程序 定义 的 某 个 原因 而 未 创建 用 户 
InvalidProviderUserKey 提供 程序 用 户 键 值 的 类 型 或 格式 无 效 
DuplicateProviderUserKey ”提供 程序 用 户 键 值 已 存在 于 应 用 程序 的 数据 库 中 


ProviderError 提供 程序 返回 一 个 未 由 其 他 MembershipCreateStatus 枚 举 值 描述 的 错误 


下 面 通过 一 个 示例 说 明 如 何 采用 成 员 资格 API 的 类 在 Stud 数据 库 中 建立 新 用 户 。 

【 例 17.3】 在 chl7 网 站 中 设计 一 个 用 于 建立 新 用 户 的 网 页 WebForml。 

解 : 其 步骤 如 下 。 

@ 打开 ch17 网 站 ,创建 一 个 网 页 WebForml. aspx。 

@ 其 设计 界面 如 图 17. 5 所 示 ,其 中 主要 包含 一 个 5X2 的 表格 .5 个 文本 框 ( 从 上 到 下 分 
别 为 TextBoxl 一 TextBox5) ,一 个 命令 按钮 Buttonl 和 一 个 标签 Labell 。 

说 明 : 为 了 简单 ,网 页 中 没有 包含 相关 的 验证 功能 。 

@ 在 网 页 上 设计 如 下 事件 过 程 : 

using System; 

using System. Web. Security; 

protected void Button1_Click(object sender, EventArgs e) 


{ MembershipCreateStatus status; 
MembershipUser user = Membership.CreateUser( 


TextBoxl1. Text, // 用 户 名 

TextBox2. Text, // 密 码 

TextBox3. Text, // 电 子 邮 箱 

TextBox4. Text, // 找 回答 案 问题 

TextBox5. Text, // 找 回答 案 回答 

true, // 是 否 批准 该 用 户 登录 

out status); // 返 回 状态 , out 表示 是 返回 型 参数 


if (user != null) 
Labell.Text = "创建 用 户 成 功 "; 
else 
{ if (status == MembershipCreateStatus.DuplicateUserName) 
Labell.Text = "用 户 已 存在 "; 
else 


462 
SP.NET 4. 5 动态 网 站 设计 教程 一 一 基于 C# 5.0 十 SQL Server 2012 
Iabell.Text = "创建 用 户 失败 "; 
@ 运行 本 网 页 ,输入 合法 的 用 户 记录 (如 密码 至 少 7 位 且 至 少 包含 一 个 特殊 字符 ,电子 邮 
箱 也 要 规范 ) ,如 图 17. 6 所 示 , 单 击 “ 确 定 ” 命 令 按 钮 ,这 样 在 Stud 数据 库 的 aspnet_Users 表 
中 增加 了 一 个 用 户 记 录 。 


CB | htp://ocalhosts0637/ch17/ WebForm1.aspx 


创建 新 用 户 
用 户 名 abc123456 
密码 1234"&56 
邮箱 | 邮箱 abc1234@126 .com 
| 变 双 我 目 月 是 ” 产 一 一 密码 找 占 问题 [ES 
| 密码 拭 回 答 业 [站 密码 找 同 答 委 。 [mybirthday 
| 确定 确定 
[LabaT 一. 创建 用 户 成 功 
图 17.5 WebForml 网 页 设计 界面 图 17.6 WebForml 网 页 运行 界面 


17.5 登录 控件 


ASP.NET 提供 了 一 组 登录 控件 ,它们 封装 了 提示 用 户 输入 凭据 及 验证 成 员 资格 系统 中 
的 凭据 所 需 的 所 有 逻辑。 也 就 是 说 , Membership 类 和 成 员 资 格 提供 程序 所 提供 的 大 多 数 功 
能 封装 在 这 几 个 登录 Web 控件 中 ,使 用 户 不 必 像 例 17. 1 那样 编程 ,这 些 登 录 控件 将 自动 使 用 
成 员 资格 系统 验证 用 户 。 这 些 控件 位 于 工具 箱 的 "登录 "类 别 中 。 


17.5.1 Login 控件 


Login 控件 显示 用 于 执行 用 户 身份 验证 的 用 户 界面 。Login 控件 包含 用 于 用 户 名 和 密码 
的 文本 框 和 一 个 复 选 框 ,该 复 选 框 可 用 于 指示 是 否 需要 服务 器 使 用 ASP.NET 成 员 身 份 存储 
他 们 的 标识 并 且 在 他 们 下 次 访问 该 网 站 时 自动 进行 身份 验证 。 

Login 控件 的 常用 属性 及 说 明 如 表 17. 9 所 示 , 其 常用 事件 及 说 明 如 表 17. 10 所 示 。 


表 17.9 Login 控件 的 常用 属性 及 其 说 明 


属 性 说 明 
CreateU serText 获取 或 设置 新 用 户 注册 页 的 链接 文本 
CreateUserUrl 获取 或 设置 新 用 户 注册 页 的 URL 
DestinationPageUrl 获取 或 设置 在 登录 尝试 成 功 时 向 用 户 显 示 的 页 面 的 URL 
DisplayRememberMe 获取 或 设置 一 个 值 , 该 值 指示 是 否 显示 复 选 框 以 使 用 户 可 以 控制 是 否 
向 浏览 器 发 送 持久 性 cookie 
FailureAction 获取 或 设置 当 登 录 尝 试 失败 时 发 生 的 操作 
FailureText 获取 或 设置 当 登 录 尝 试 失败 时 显示 的 文本 
Password 获取 用 户 输入 的 密码 


PasswordLabel Text 获取 或 设置 Password 文本 框 的 标签 文本 


属 性 


第 17 章 成员 资 格 和 角色 管 圈 


续 表 


说 明 


PasswordRecoveryText 
PasswordRecoveryUrl 


PasswordRequiredErrorMessage 


RememberMeSet 


RememberMeText 
UserName 
UserNameLabelText 


UserNameRequiredErrorMessage 


获取 或 设置 密码 恢复 页 链接 的 文本 

获取 或 设置 密码 恢复 页 的 URL 

获取 或 设置 当 密 码 字段 为 空 时 在 ValidationSummary 控件 中 显示 的 错 
误 消 息 

获取 或 设置 一 个 值 ,该 值 指示 是 否 将 持久 性 身份 验证 cookie 发 送 到 用 
户 的 浏览 器 

获取 或 设置 “ 记 住 我 " 复 选 框 的 标签 文本 

获取 用 户 输入 的 用 户 名 

获取 或 设置 UserName 文本 框 的 标签 文本 

获取 或 设置 当 用 户 名 字段 为 空 时 在 ValidationSummary 控件 中 显示 的 
错误 消息 


表 17.10 Login 控件 的 常用 事件 及 其 说 明 


事件 


说 明 


Authenticate 
DataBinding 
LoggedIn 
LoggingIn 


LoginError 


在 验证 用 户 的 身份 后 出 现 

当 服 务 器 控件 绑 定 到 数据 源 时 发 生 

在 用 户 登 录 到 网 站 并 进行 身份 验证 后 出 现 

在 用 户 未 进行 身份 验证 而 提交 登录 信息 时 出 现 
当 检 测 到 登录 错误 时 出 现 


说 明 : ASP.NET 成 员 资 格 和 ASP.NET 登录 控件 隐 式 地 使 用 Forms 身份 验证 。 
【 例 17.4】 在 ch17 网 站 中 使 用 Login 控件 设计 一 个 用 于 用 户 登录 的 网 页 WebForm2。 


解 : 其 步骤 如 下 。 


Q@ 打开 ch17 网 站 ,创建 一 


个 网 页 WebForm2. aspx。 


@ 在 网 页 中 添加 一 个 Login 控件 ,如 图 17.7 所 示 ,并 通过 “Login 任务 ”中 的 “自动 套用 格 
式 ” 设 置 其 套用 格式 为 “传统 型 ”。 

加 创建 一 个 名 为 WebForm2-1 的 网 页 ,其 中 仅 含 有 一 个 “您 已 成 功 登 录 .…… ”的 HTML 
标签 。 然 后 将 WebForm2 网 页 中 Login 控件 的 DestinationPageUrl 属性 设 为 “~/ 


WebForm2-1. aspx”。 
@ 运行 WebForm2 网 页 ， 


输入 合法 的 用 户 记 录 , 单 击 “ 登 录 ” 按 钮 ,登录 成 功 并 转向 


WebForm2-1 网 页 ,如 图 17.8 所 示 。 


Es = 
厂 下 冰 记 会 委 - 


| 


17.7 添加 一 个 Login 控件 


个 ) 个 http://iocalhost5063 记 
sara | 站 localhost x 


你 已 戌 功 登 录 . ..... 


图 17.8 WebForm2 网 页 运行 结果 


注意 : 在 默认 情况 下 ,Login 控件 要 求 用户 填 写 的 密码 的 格式 为 至 少 有 7 位 以 上 的 长 度 ， 
至 少 包含 一 个 数字 和 一 个 符号 字符 。 
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17.5.2 ”其 他 登录 控件 


其 他 登录 控件 及 其 功能 说 明 如 下 。 

。 ChangePassword 控件 : 允许 用 户 更 改 其 密码 。 用 户 必 须 先 提供 原始 密码 ,然后 再 创 
建 并 确认 新 密码 。 如 果 原 始 密码 正确 , 则 用 户 密码 将 更 改 为 新 密码 。 

。 CreateUserWizard 控件 : 用 于 收集 潜在 用 户 所 提供 的 信息 。 

。 LoginName 控件 : 用 于 显示 当 用 户 使 用 ASP.NET 成 员 身 份 登录 时 的 用 户 登录 名 。 
如 果 网 站 使 用 集成 的 Windows 身份 验证 , 则 该 控件 显示 用 户 的 Windows 账户 名 。 

。 LoginStatus 控件 : 为 没有 通过 身份 验证 的 用 户 显 示 登 录 链 接 ,为 已 通过 身份 验证 的 用 

户 显示 注销 链接 。 登 录 链 接 将 用 户 带 到 登录 页 ,注销 链接 将 当前 用 户 的 标识 重 置 为 匿 

名 用 户 。 

LoginView 控件 : 可 用 于 向 匿名 用 户 和 登录 用 户 显示 不 同 的 信息 。 

。 PasswordRecovery 控件 : 可 以 根据 创建 账户 时 所 使 用 的 电子 邮件 地 址 找 回 用 户 密码 。 
该 控件 会 向 用 户 发 送 包含 密码 的 电子 邮件 。 

这 些 登 录 控 件 的 使 用 方法 与 Login 控件 类 似 ,这 里 不 再 详 述 。 


17.6 角色 管理 


可 以 把 用 户 分 为 特定 的 类 型 ,每 种 类 型 的 用 户 只 能 做 特定 的 事情 ,这 种 用 户 的 分 类 称 为 角 
色 。 角 色 可 以 看 成 是 具有 特定 权限 的 用 户 集合 。 

角色 管理 主要 帮助 管理 授权 ,允许 指定 应 用 程序 中 的 用 户 可 以 访问 的 资源 。 角 色 管 理 允 
许 向 角色 分 配 用 户 ( 如 abc123456 用 户 等 ), 从 而 将 用 户 组 视 为 一 个 单元 。 在 Windows 中 ,可 
以 通过 将 用 户 分 配 到 组 (如 Administrators、 超 级 用 户 等 ) 来 创建 角色 。 

建立 角色 后 ,可 以 在 应 用 程序 中 创建 访问 规则 。 例 如 ,站 点 中 可 能 包括 一 组 只 希望 对 成 员 
显示 的 网 页 。 同 样 ,可 能 希望 根据 当前 用 户 是 否 是 管理 员 而 显示 或 隐藏 页 面 的 一 部 分 。 使 用 
角色 ,可 以 独立 于 单个 应 用 程序 用 户 建立 这 些 类 型 的 规则 。 例 如 ,无 须 为 站 点 的 各 个 成 员 授予 
权限 ,允许 他 们 访问 仅 供 成 员 访 问 的 网 页 。 

一 个 用 户 可 以 具有 多 个 角色 。 例 如 ,如 果 网 站 是 一 个 论坛 , 则 有 些 用 户 可 能 同时 具有 成 员 
角色 和 版 主角 色 , 可 能 定义 每 个 角色 在 站 点 中 拥有 不 同 的 特权 ,同时 具有 这 两 种 角色 的 用 户 将 
有 具有 两 组 特权 。 

若 要 使 用 角色 管理 ,首先 要 启用 它 ,并 配置 能 够 利用 角色 的 访问 规则 (可 选 ) ,然后 可 以 在 运 
行 时 使 用 角色 管理 功能 处 理 角色 。 如 下 所 示 的 设置 在 应 用 程序 的 Web. config 文件 中 启用 它 ， 


<roleManager 
enabled = "true" 
cacheRolesIncookie = "true" > 
</roleManager > 
角色 的 典型 应 用 是 建立 规则 ,用 于 允许 或 拒绝 对 页 面 或 目录 的 访问 。 用 户 可 以 在 Web. 
config 文件 的 authorization 元 素 部 分 设置 此 类 访问 规则 。 
以 下 示例 允许 members 角色 的 用 户 查 看 名 为 memberPages 的 目录 中 的 网 页 ,同时 拒绝 
任何 其 他 用 户 的 访问 : 
<configuration> 
< location path= "memberPages"> 
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< System. web > 
<authorization > 
<allow roles = "members" /> 
< deny users ="*" /> 
</authorization > 
</ system. web > 
</location> 
<conf iguration> 
另外 还 必须 创建 管理 员 ( 如 manager) 或 普通 用 户 ( 如 member) 之 类 的 角色 ,并 将 用 户 ID 
分 配给 这 些 角色 。 
如 果 使 用 表单 身份 验证 ,可 以 通过 调用 各 种 角色 管理 器 方法 以 编程 方式 执行 此 任务 。 
Roles 类 提供 了 一 系列 的 静态 方法 与 属性 ,完成 角色 管理 的 相关 功能 ,例如 ,以 下 代码 示例 表 
示 创 建 和 角色 members: 


Roles. CreateRole("members" ); 


注意 : 对 于 配置 角色 管理 .定义 角色 、 向 角色 中 添加 用 户 和 创建 访问 规则 而 言 ,最 简单 的 
方法 是 使 用 网 站 管理 工具 (将 在 下 一 节 介绍 ) 。 


17.7 使 用 向 导 配 置 安全 性 


es ASP. NET 网 站 管理 工具 可 以 方便 地 实现 成 员 和 角色 管理 ,也 就 是 使 用 向 导 配 置 安 
。 该 向 导 几 乎 可 以 完成 所 有 的 成 员 和 角色 管理 功能 ,下 面 通过 一 个 示例 说 明 该 向 导 的 使 

J 

【 例 17.5】》 使 用 向 导 创 建 一 个 用 户 Mary ,创建 一 个 角色 manager( 允 许 访问 ch17 网 站 的 
App_Data 目录 ) ,并 将 manager 角色 分 配给 Mary 用 户 。 

解 : 其 步骤 如 下 。 

Q@ 打开 ch17 网 站 ,选择 “网 站 |ASP.NET 配置 "命令 ,出 现 "“ASP.NET 网 站 管理 工具 ”对 
话 框 ,图 17. 9 所 示 为 “主页 ”选项 卡 ,其 中 6 个 用 户 是 在 前 面 执 行 示 例 网 页 时 创建 的 。 


Ge@ 
ASP nwara 


欢迎 使 用 网 站 管理 工具 


应 用 程序 :/ch17 
当前 用 户 名 :LCB-PCVADMINISTRATOR 


六 其 流下 和 本 用户 、 前 色 和 对 站 上 的 访 各 要” 
应 用 程 库 析 时 使 你 能 名 管理 应 用 程序 的 配 轩 设置 > 


图 17.9 “ASP.NET 网 站 管理 工具 ”对 话 框 


@ 选择 “安全 ”选项 卡 , 出 现 如 图 17. 10 所 示 的 对 话 框 , 单 击 “ 使 用 安全 设置 向 导 按 部 就 班 
地 配置 安全 性 ” 超 链接 。 
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= ee ] 


记 
所 kK | @ http://\ocalhost52345/asp.netwebadminfiles/security/security.aspx Dre 二 
钨 ASp.Net Web 应 用 程序 管理 x ] 


可 以 使 用 网 站 管理 工具 来 管理 应 用 程序 的 所 有 安全 设置 。 可 以 设置 用 户 和 密码 (身份 验证 )， 可 以 创建 角色 (用 户 组 ) 
还 可 以 创建 权限 (用 于 控制 对 应 用 程序 各 个 部 分 的 访问 的 规则 )。 


默认 情况 下 ， 用 户 信息 存储 Microsoft SQL Server Express 才 据 库 中 ， 该 数据 库 在 网 站 和 Data 文件 夹 中 。 如 果 
要 将 用 户 信息 存储 在 其 他 数据库 中 ， 请 使 用 "提供 程序 ”选项 卡 选 择 其 他 提供 程序 。 


单 击 表 中 的 链接 以 管理 应 用 程序 的 设置 
用 户 
现 有 用 户 : 6 
创建 用 户 


CE 


未 启用 角色 
启用 角色 


时 或 管理 角色 


图 17.10 “安全 ”选项 卡 
@ 出 现 “ 欢 迎 使 用 安全 设置 向 导 ” 对 话 框 ,按照 左边 列 出 的 7 个 步骤 可 以 创建 和 角色、 创建 
用 户 和 访问 规则 等 。 


@ 在 步骤 2 中 选中 “通过 Internet”, 在 步骤 4 中 选中 “为 此 网 站 启动 角色 ”, 单 击 “ 下 一 步 " 按 钮 。 
@ 为 网 站 添加 两 个 角色 , 单 击 “ 下 一 步 " 按 钮 。 


@ 出 现 “ 注 册 新 账户 ”对 话 框 ,创建 一 个 新 用 户 , 如 图 17. 11 所 示 , 单 击 “ 下 一 步 " 按 钮 。 


通过 在 此 页 中 输入 用 9 ID 、 密 码 和 电子 邮件 未 未 加 用 户 。 还 可 以 指定 本 和 回答 ， 用 户 必须 给 
出 与 上 bj 管 才能 重 置 密码 或 请求 忘记 的 密码 。 


安全 提示 问题 : 
安全 答案 : 


图 17. 11 “注册 新 账户 ”对 话 框 
@ 出 现 “ 添 加 新 访问 规则 ”对 话 框 ,设置 manager 角色 可 以 访问 ch17 下 面 的 App_Data 目 
录 , 如 图 17. 12 所 示 , 单 击 “ 完 成 ”按钮 。 


@ 回 到 “主页 ”选项 卡 , 单 击 “ 管 理 用 户 ” 超 链接 ,出 现 如 图 17. 13 所 示 的 “搜索 用 户 ” 对 话 
框 , 单 击 Mary 后 的 “编辑 用 户 ” 超 链接 。 
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ee 如 本义 了 多 个 培 则 ,mliaesM 近 表 中 时 示 9 序 应 用 。 应 用 第 一 个 符 羡 条件 名 可 以 在 以 后 
加 、 移 除 、 信和 重 指 R 则 。 


为 此 规则 选择 一 个 目录 : 


绰 自 ”chl7 
App_Data 


图 17.12 添加 一 个 规则 


| @ http://localhost52345/asp.netwebadminfiles/security/users/manageUsers.aspx pre Fr 


| 名 ASP.Net web 应 用 委 序 芝 理 x 


主页 实 全 应 用 各 序 所 供 程序 ~ 


单 击 一 行 选择 一 个 用 户 ， 然 后 单 击 "编辑 用 户 " 查 看 或 更 改 该 用 户 的 密码 或 其 他 属性 。 若 要 为 选 定 的 用 户 分 配角 色 ， 可 选择 右 便 相应 的 复 选 
框 * 


车 要 禁止 读 用 户 登录 到 您 的 应 用 程序 ， 但 在 数据 床 中 保留 其 信息 ， 可 通过 酒 除 相应 的 复 选 框 将 其 状态 设置 为 丰 活 动 的 * 


搜索 依据 : [用 户 名 ”|] 搜索 内 容 : | 下 找 用 户 


允许 使 用 通配符 ~” 和?。 
全 部 


活动 


< 图 < 几 < 图 < 


上 上 二 作 


图 17.13 “搜索 用 户 ” 对 话 框 


加 为 Mary 用 户 分 配 manager 角色 , 即 选 中 “为 此 用 户 选 择 角色 ”下 方 的 manager, 如 
17. 14 所 示 。 

网 站 管理 工具 除了 上 述 管理 用 户 账户 和 角色 的 设置 外 ,还 可 以 使 用 “应 用 程序 ”选项 卡 来 
管理 影响 ASP.NET a ge ee 
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在 此 页 中 可 以 编辑 用 户 信息 ， 指 定 用 户 所 属 的 角色 。 


用 户 
用户 ID: 。 Mey ] 为 此 用 户 选择 角色 : 
米 电子 邮件 地 址 mary@126com |] manager 
说 明 : [ 款 设 二 ] 

(四 必 填 字段 


图 17.14 为 Mary 用 户 分 配 manager 角色 


测试 或 分 配 应 用 程序 提供 程序 的 设置 。 


练习 题 17 


. 简 述 成 员 资格 管理 的 体系 结构 。 

. 简 述 配置 成 员 资格 的 基本 过 程 。 

. 简 述 成 员 资格 API 层 有 哪些 主要 的 类 ,各 有 什么 功能 ? 

. 简 述 SqlMembershipProvider 提供 程序 的 主要 功能 。 

. 简 述 登录 控件 的 主要 功能 ,在 开放 网 站 时 是 否 必须 使 用 登录 控件 ? 
. 简 述 角色 的 概念 ,在 ASP.NET 中 为 什么 引入 角色 ? 

. 简 述 ASP.NET 网 站 管理 工具 的 主要 用 途 。 


上 机 实验 题 17 


在 chl7 网 站 中 添加 一 个 Experment17 网 页 ,采用 ASP.NET 登录 控件 ChangePassword 
实现 用 户 密码 的 更 改 ,其 运行 界面 如 图 17. 15 所 示 。 


~ 中 oo 


图 17.15 上 机 实验 题 17 网 页 的 运行 结果 


学 生成 绩 管 理 网 站 设计 第 18 章 


学 生成 绩 管理 网 站 是 一 个 中 小 型 网 站 ,本 章 介 绍 该 网 站 的 详细 设计 过 程 ， 
包括 数据 库 设计 和 动态 网 页 设计 等 。 

本 章 学 习 要 点 : 

掌握 采用 ASP .NET 4.5 十 C# 十 SQL Server 2012 开发 中 小 型 网 站 的 
方法 。 


18.1 网 站 功能 


学 生成 绩 管理 网 站 用 于 实现 学 生 、 教 师 、 课 程 的 管理 ,以 及 课程 安排 ,学 生 
网 上 选课 教师 网 上 成 绩 输入 和 学 生 网 上 成 绩 查 询 等 。 其 主要 功能 如 下 : 
Q@ 用 户 分 为 学 生 、 教 师 和 管理 员 3 种 类 型 ,如 图 18. 1 所 示 。 


Ee sn | 有 


学 生成 绩 管理 系统 


StudDB 


图 18.1 3 类 系统 用 户 


@ 管理 员 可 以 输入 和 编辑 学 生 ,教师 .课程 和 管理 员 用 户 数据 。 

@ 管理 员 可 以 更 改 自 己 的 密码 ,安排 教师 讲授 课程 以 及 查看 学 生成 绩 。 

@ 学 生 可 以 更 改 自己 的 密码 .选修 课程 和 取消 课程 ` 列 自己 的 选课 单 .查看 
自己 的 成 绩 。 

@ 教师 可 以 更 改 自己 的 密码 .输入 和 修改 所 授课 程 的 学 生成 绩 和 查看 该 
成 绩 。 
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网 站 设计 要 求 如 下 : 

@ 学 生 学 号 .教师 编号 .课程 编号 和 管理 员 编 号 都 是 唯一 的 。 

@ 一 个 学 生 可 以 选修 多 门 课程 ,一 个 教师 可 以 讲授 多 门 课程 ,但 每 门 课 程 最 多 只 有 一 个 
教师 讲授 。 

@ 学 生 按 课 程 编号 进行 选修 ,也 就 是 说 ,在 学 生 选 课 前 不 一 定安 排 了 课程 的 讲课 教师 。 

@ 在 第 一 次 输入 各 类 人 员 的 信息 时 ,密码 与 其 编号 相同 ,每 个 人 只 能 修改 自己 的 密码 。 

@ 所 有 的 修改 操作 不 能 修改 编号 。 

@ 教师 只 能 输入 自己 上 课 课 程 的 学 生成 绩 ,学 生 只 能 查看 自己 的 成 绩 ,管理 员 可 以 查看 
所 有 学 生成 绩 。 


18.2 数据 库 设计 


学 生成 绩 管理 网 站 采用 SQL Server 2012 Express 设计 数据 库 ,数据 库 名称 为 StudDB, 其 
中 包含 6 个 表 。 

。 学 生 表 student: 该 表 用 于 存放 学 生 的 基本 信息 (由 管理 员 输入 ), 其 表 结 构 如 图 18. 2 
所 示 , 包 含 的 列 有 sno( 学 号 ) .sname( 姓 名 )、ssex( 性 别 ) .snation( 民 族 ) .sclass( 班 号 ) 
和 spass( 密 码 ) ,其 中 sno 为 主键 。 

。 教师 表 teacher: 该 表 用 于 存放 教师 的 基本 信息 (由 管理 员 输 入 ), 其 表 结 构 如 图 18. 3 
所 示 , 包 含 的 列 有 tno( 教 师 编号 ) .tname( 姓 名 ) ,tsex( 性 别 ) tdepart( 系 别 ) 和 tpass 
(密码 ) ,其 中 tno 为 主键 。 


LCB-POSQLEXPRE...B - dbo.student x 


LCB-PO\SQLEXPRE...B - dbo.teacher x 


区 国 char(10) 固 列 名 数据 类 型 多 许 Null 值 
sname char(10) 贺 好 tno char(10) 回 
ssex char(2) 加 tname char(10) 园 
snation char(10) 回 tsex char(2) 加 
sclass char(10) 加 tdepart char(20) 
spass char(10) 贺 tpass char(10) 贺 

回 
图 18.2 student 表 结 构 图 18.3 teacher 表 结 构 


。 管理 员 表 manager: 该 表 用 于 存放 管理 员 的 基本 信息 (由 管理 员 输 入 ) ,其 表 结 构 如 
图 18.4 所 示 , 包 含 的 列 有 mno( 管 理 员 编 号 ) .mname( 姓 名 ) 和 mpass (密码 ), 其 中 
mno 为 主键 。 

。 课程 表 course: 该 表 用 于 存放 所 有 课程 的 课程 名 和 上 课 情况 的 信息 (由 管理 员 输 入 并 
安排 上 课 教 师 ) ,其 表 结 构 如 图 18. 5 所 示 , 包 含 的 列 有 cno( 课 程 号 )、cname (课程 名 )、 
ctime( 上 课时 间 )、cplace( 上 课 地 点 )、tno( 上 课 教 师 编号 ) 和 tname( 上 课 教师 姓名 ) ,其 
中 cno 为 主键 。 为 了 便于 查询 ,其 中 设计 了 tname 元 余 列 。 

。 成 绩 表 score: 该 表 用 于 存放 所 有 学 生 的 成 绩 ( 由 任课 教师 输入 或 修改 ), 其 表 结 构 如 
图 18. 6 所 示 , 包 含 的 列 有 sno( 学 号 )、sname( 姓 名 )、cno( 课 程 号 )、cname( 课 程 名 )、 
degree( 分 数 ) 和 tno( 上 课 教 师 编号 ) ,没有 主键 。 为 了 便于 成 绩 查 询 、 输 入 和 修改 ,其 

中 设计 了 sname 和 cname 宛 余 列 。 
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LCB-POASQLEXPRE..DB - dbo.course Xx 
列 名 数 手 关 型 允许 Null 值 


boao char(10) 固 
LCB-PO\SQLEXPR.B - dbo.manager xX cname char(20) 回 
列 名 数据 类 型 人 t 许 Null 值 cime char(10) 贺 
mnqd| char(10) 回 cplace char(20) 园 
mname char(10) 贺 tno char(10) 贺 
mpass char(10) 加 tname char(10) 贺 
加 回 

图 18.4 manager 表 结 构 图 18.5 course 表 结构 


。 学 生 选 课表 selcourse: 该 表 用 于 临时 存放 学 生 选 课 情 况 ( 由 学 生 在 选课 时 修改 ) ,其 表 
结构 如 图 18.7 所 示 ,包含 的 列 有 sno( 学 号 ) .cno( 课 程 号 ) .cname( 课 程 名 ) .ctime( 上 
课时 间 ) .cplace( 上 课 地 点 ) .tno( 上 课 教师 编号 ) ,tname( 上 课 教师 ) 和 sel( 选 修 否 ), 没 
有 主键 。 为 了 便于 成 绩 查询 .输入 和 修改 ,其 中 设计 了 多 个 宛 余 列 。 一 旦 某 学 生 确 认 
了 选课 情况 , 则 将 其 所 有 选课 记录 转 和 人 score 表 中 ,从 selcourse 表 中 删除 该 生 的 记录 ， 
并 且 不 能 再 进行 选课 操作 。 


LCB-PC\SQLEXPRES..- dbo.selcourse x | 
列 名 数据 类 型 允许 Null 值 
LCB-PCNSQLEXPRE..dDB - dbouscore Xx | bsnd | char(10) 贺 
列 名 天 型 允许 Null 什 ano char(10) 国 
plsno char(10) 贺 cname char(20) 国 
sname char(10) 司 cime char(10) 国 
no char(10) 回 cplace char(20) 国 
cname char(20) 贺 tno char(10) 加 
degree int 团 tname char(10) 
tno char(10) 加 sel char(2) 团 
回 回 
图 18.6 score 表 结 构 图 18.7 selcourse 表 结 构 


在 上 述 表 中 包含 了 一 些 宛 余 字段 ,所 谓 元 余 字 段 是 指 这 些 信息 可 以 从 其 他 表 通 过 表 连 接 
得 到 。 但 为 了 提高 运算 效率 ,减轻 服务 器 的 负担 ,这 样 的 设计 是 合适 的 。 


18.3 网 站 设计 


18.3.1 建立 网 站 


首先 选择 “文件 | 新 建 | 网站” 命令, 出现 “新建 网 站 ”对话 框 , 选 择 “ASP.NET 空 网 站 ” 模 
板 ,设置 *<Web 位 置 "为 “文件 系统 ”, 单 击 “ 浏 览 ” 按 钮 .选择 “D:\ASP .NET\ 学 生成 绩 管理 系 
统 " 目 录 , 单 击 “ 确 定 ” 按 钮 ,创建 一 个 空 的 学 生成 绩 管理 系统 网 站 ,然后 在 其 中 添加 网 页 等 。 

本 网 站 的 所 有 文档 存放 在 "“D:\ASP.NET\ 学 生成 绩 管理 系统 ”目录 中 ,网 站 的 首页 为 
default. aspx, 在 IE 浏览 器 的 地 址 栏 中 输入 “http://localhost:49239” 后 按 回 车 键 即 可 启动 本 
网 站 。 


18.3.2 网 站 布局 
本 网 站 的 布局 如 图 18. 8 所 示 , 所 有 网 页 文件 分 类 存放 。 
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对 各 文件 夹 的 说 明 如 下 。 


App_Data 文件 夹 : 用 于 存放 StudDB 数据 库 文件 。 
App _Code 文件 夹 : 存放 数据 库 访问 类 文件 
CommDB. cs。 

images 文件 夹 : 存放 一 些 图 片 (top. jpg、 bottom 
.jpg 等 )。 

App_Themes 文件 夹 : 存放 主题 Blue 和 StyleSheet 
. css 样式 文件 。 

Manager 文件 夹 : 存放 管理 员 的 主要 网 页 文件 。 
Student 文件 夹 : 存放 学 生 的 主要 网 页 文件 。 
Teacher 文件 夹 : 存放 教师 的 主要 网 页 文件 。 

根 目录 : 存放 Web. config( 配 置 文 件 )、Default. aspx 
(主页 文件 )、MasterPage. master ( 母 版 页 文件 )、 


SoH Oo-e0a 
接 紊 解决 方案 资源 管理 匡 (Ctrl+;) 


团 解决 方案 “localhost 49239"” (1 个 项 目 ) 
ERETEREO 
国 App Code 
App_Data 
闻 App Themes 
4 国 Blue 
A SkinFile.skin 
B sylesheetcss 
images 
国 Manager 
国 Student 
国 Teacher 
Defaultaspx 
dispinfo.aspx 
managermenu.aspx 
回 MasterPage.master 
A studentmenu.aspx 
A teachermenu.aspx 


D web.config 


dispinfo. aspx (公共 显 示 网 页 文件 )、mamanermenu 
.aspx( 管 理 员 菜单 网 页 文件 )、studentmenu. aspx 
(学 生菜 单 网 页 文件 ) 和 teachermenu. aspx( 教 师 菜 
单 网 页 文件 ) 。 


18.4 网 页 设计 


本 网 站 的 所 有 文件 分 为 5 个 部 分 , 即 通用 功能 、 主 页 、 管 理 员 网 页 ,学 生 网 页 和 教师 网 页 ， 
下 面 分 别 介 绍 。 


18.4.1 通用 功能 设计 


通用 功能 由 Web. config、CommDB. cs、 Stylesheet. css、 SkinFile. skin 和 MasterPage. 
master( 母 版 页 文件 ) 组 成 。 

1. Web. config 配置 文件 

本 网 站 的 Web. config 配置 文件 十 分 简单 ,由 于 没有 采用 ASP.NET 的 特定 登录 功能 ,不 
需要 配置 提供 程序 ,其 内 容 如 下 : 


<?xml version = "1.0"?> 
<configuration > 
<appSettings > 
<add key = "ValidationSettings:UnobtrusiveValidationMode" value = "None" /> 
</appSettings > 
<connectionStrings > 
<add name = "myconnstring” 
connectionString = "Data Source = LCB— PC\SQLEXPRESS; Initial Catalog = StudDB; 
User ID = sa;Password = 12345" providerName = "System. Data. SqlClient"/> 
</connectionStrings > 
<system.web> 
<authentication mode = "Forms"> 
< forms loginUrl = "Default. aspx"/> 
</authentication> 
<compilation debug = "true" targetFramework = "4.5"> 


图 18.8 网 站 布局 
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</compilation> 
< httpRuntime targetFramework = "4.5"/> 
</system. web > 
</configuration> 


2. CommDB. cs 
该 类 文件 包括 通用 数据 库 访问 方法 和 随机 产生 验证 码 方法 等 ,被 其 他 网 页 引用 。 该 文件 
的 代码 如 下 : 


using System; 
using System, Data; 
using System. Data. SqlCl ient; 
public class CommDB 
{ public CommDB() {} // 上 默认 构造 函数 
// 关 尖 闫 关 尖 闪闪 闫 关 尖 尖 关 闫 关 关 闫 尖 关 关 闫 关 关 关 关 美英 关 闫 关 尖 尖 关 英 闫 尖 尖 关 关 尖 关 关 关 关 关 关 关 关 关 关 关 关 关 闫 关 关 关 关 关 关 关 关 关 关 关 关 关 
// 返 回 SELECT 语句 执行 后 记录 集中 的 行 数 
AN 关 尖 关 关 尖 闪闪 关 关 尖 尖 关 关 闪闪 关 尖 尖 尖 闪闪 尖 尖 闪闪 关 关 关 关 尖 尖 关 关 关 关 尖 关 关 尖 闪闪 关 尖 尖 关 关 关 尖 尖 关 尖 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 
public int Rownum( string sql, string tname, ref string sname) 
{ inti=0; 
string mystr = System.Configuration. ConfigurationManager. 
ConnectionStrings["myconnstring" ].ToString(); 
SqlConnection myconn = new SqlConnection(); 
myconn. ConnectionString = mystr; 
myconn. Open( ); 
SqlCommand mycmd = new SqlCommand( sql, myconn); 
SqlDataReader myreader = mycmd.ExecuteReader(); 
while (myreader. Read() ) // 循 环 读 取信 息 
{ sname = myreader[0].ToString(); 
i++3} 
} 
myconn. Close( ); 
return i; 
} 
/六 关 尖 并 尖 计 关 守 关 关 容 关 关 六 关 关 关 关 关 关 并 六 关 六 关 关 并 关 关 闪 关 关 并 关 并 闪闪 关 湛江 闫 并 闪 关 并 关 关 并 闪闪 关 关 关 关 关 关 关 关 关 关 关 关 关 关 
// 执 行 SQL 语句 ,返回 是 否 成 功 执行 .SQL 语句 最 好 是 如 下 : 
//UPDATE 表 名 SET 字段 名 = value, 字段 名 = value WHERE 字段 名 = value 
//DELETE FROM 表 名 WHERE 字段 名 = value 
//INSERT INTO 表 名 (字段 名 ,字段 名 ) values (value, value) 
EN 关 尖 闪闪 关 尖 关 关 闪光 闪闪 舌尖 关 尖 关 尖 尖 关 闪光 关 尖 关 尖 闫 尖 关 关 尖 关 尖 关 关 尖 关 关 关 关 关 闪闪 关 关 闪闪 闪闪 关 关 关 关 闪闪 关 关 闪 关 关 关 关 关 关 关 关 
public Boolean ExecuteNonQuery( string sql) 
. string mystr = System. Configuration. ConfigurationManager. 
ConnectionStrings["myconnstring"]. ToString(); 
SqlConnection myconn = new SqlConnection(); 
myconn. ConnectionString = mystr; 
myconn. Open(); 
SqlCommand mycmd = new SqlCommand( sql,myconn); 
try 
{ mycmd.ExecuteNonQuery(); 
myconn. Close( ); 
} 
catch 
{ myconn. Close( ); 
return false; 
} 
return true; 
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} 
人 
// 执 行 SELECT 语句 ,返回 DataSet 对 象 
人 
public DataSet ExecuteQuery(string sql, string tname) 
{ string mystr = System. Configuration. ConfigurationManager. 
Connect ionStrings[ "myconnstring" ]. ToString(); 

SqlConnection myconn = new SqlConnection(); 

myconn. ConnectionString = mystr; 

myconn. Open(); 

SqlDataAdapter myda = new SqlDataAdapter( sql,myconn); 

DataSet myds = new DataSet(); 

myda. Fill(myds, tname); 

myconn. Close( ); 

return myds; 
} 
/闪闪 闪闪 闪闪 尖 闫 闪闪 关 尖 美英 尖 关 关 尖 美 关 闫 关 关 半 尖 英美 关 尖 尖 闫 关 尖 关 兴 闫 关 关 关 闫 尖 关 关 关 关 尖 闫 关 关 尖 关 关 关 关 关 英 关 关 关 关 关 关 关 关 关 关 
/// 实现 随机 验证 码 : 返 回 生成 的 随机 数 
/闪闪 闪闪 闪光 闪闪 闪闪 关 尖 关 关 尖 关 尖 尖 关 尖 闪 关 闪闪 尖 闪 闫 关 尖 关 尖 关 关 尖 关 尖 关 关 关 尖 闪闪 闪闪 尖 关 尖 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关头 关 关 关 
public string RandomNum( int n) ”//n 为 验证 码 的 位 数 
{ 。// 定 义 一 个 包括 数字 ,大 写 英文 字母 和 小 写 英文 字母 的 字符 串 

String strchar = "0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H," + 

"I,J,K,L,M,N,O0,P,Q,R,S,T,U,V,W,X,Y,2Z," + 

"asb,c,d, e,f,g,h,i,j,k, l,m,n,o,p,qir,s,t, UV Ww, X,Y 2"; 

// 将 strchar 字符 串 转化 为 数组 

//String. Split 方法 返回 包含 此 实例 中 的 子 字符 串 的 String 数组 

string[] arry = strchar. Split(', '); 


mm 


string num = 
// 记 录 上 次 的 随机 数值 ,尽量 避免 产生 几 个 一 样 的 随机 数 
int temp = 一 1; 


// 采 用 一 个 简单 的 算法 保证 生成 随机 数 的 不 同 
Random rand = new Random( ) ; 
for (inti = 1; i<n+ 1; i++) 
{ if(temp!= -1) 
{ ”//unchecked 关键 字 用 于 取消 整 型 算术 运算 和 转换 的 溢出 检查 
//DateTime. Ticks 属性 获取 表示 此 实例 的 日 期 和 时 间 的 刻度 数 
rand = new Random(i * temp * unchecked( (int)DateTime.Now.Ticks)); 
} 
//Random. Next 方法 返回 一 个 小 于 所 指定 最 大 值 的 非 负 随机 数 
int t = rand. Next(61); 


if (temp != -1 && temp == t+) 
return RandomNum(n); 
temp = t; 
num += arry[t]; 
} 
return num; // 返 回 生成 的 随机 数 


} 


3. StyleSheet. css 样式 文件 
该 文件 包含 一 些 样式 定义 ,被 其 他 网 页 引用 。 该 文件 的 代码 如 下 : 
.auto— stringstyle /* 输入 文本 框 提示 文字 样式 */ 
{ ”font family: 楷体 ; 
font — size: medium; color: 井 0000FF; 
font — weight: bold; text ~ align:right; 
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} 
.auto — captionstyle /* 标题 样式 * / 
{ font - size: 16pt; color: #ff0099; 

font - family: 幼 font — weight: bold; 

text ~ align:center; height:40px; 

width: 436px; 
} 
.auto— resettyle /x 重 置 按 钮 样式 */ 
' font — weight: bold; color: red; 

font - family: 黑体 ; font- size: medium; 
} 
a:visited /* 定 义 超 链接 被 访问 过 后 的 显示 颜色 * / 
text - decorat ion:none; 

color: #0000FF; font - weight :bold; 
} 
a:link /* 定义 正常 显示 的 超 链接 颜色 * / 


{ text— decoration:none; 
color: # FF6A00;font - weight:bold; 


} 

间 tablecenter /* 表格 居中 样式 * / 

{ margin- left: auto; margin 一 right: auto; 
vertical ~ align: middle; background— color: 井 99ccff; 
width: 426px; height: 206px; 

} 


4. SkinFile. skin 皮肤 文件 
该 文件 包含 一 些 主 题 样式 定义 ,被 其 他 网 页 引用 。 该 文件 的 代码 如 下 : 


<asp:Label runat = "server" style= "color: 提 CCFF33;background— color: 井 9900CC; 
font - size: medium; font - weight: 700;font - family: 楷体 ;" /> 
<asp:Button runat = "server" style= "color: red; font - size: medium; font - weight: 700; 
font - family: 黑体 " Text = "Button" /> 
<asp:TextBox runat = "server" style= "font - size: small;background— color:white" /> 
<asp:RequiredFieldValidator runat = "server" 
style= "font family: 仿宋 ; font - size:16px; color: 井 800080;font - weight: bold" /> 
<asp:CompareValidator runat = "server" 
style= "font- family: 仿宋 ; font - size:16px; color: 井 800080;font - weight: bold" /> 
<asp:RadioButton runat = " server" 
style= "font- family: 宋体 ; font - size: small; color: 井 008080; font - weight: bold" /> 
<asp:DropDownList runat = "server" 
style= "font— size: small;background - color:white;width:120px" /> 
5. MasterPage. master 
母 版 页 中 包含 一 个 3X 3 的 表格 ,第 1 行 放置 images/top. jpg 图 形 文件 ,第 3 行 放置 
images/bottom. jpg 图 形 文件 ,第 2 行 的 第 1 列 和 第 3 列 各 放置 一 个 images/edges. jpg 图 形 文 
件 , 第 2 行 的 第 2 列 放置 一 个 ContentPlaceHolder 控件 ContentPlaceHolderl ,其 设计 界面 如 
图 18. 9 所 示 。 其 源 视图 代码 如 下 ， 
<% @ Master Language = "C#" AutoEventWireup= "true" CodeFile = "MasterPage.master.cs" 
Inherits = "MasterPage" %> 
<html xmlns = "http://www.w3.org/1999/xhtml" > 
<head runat = "server"> 
<title > 欢迎 使 用 学 生成 绩 管理 系统 </title> 


<style type = "text/css"> 
.auto— stylel { 
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width: 2%; 
height: 100%; 
} 
.auto— style2 { 
width: 96%; 
height: 100%; 
} 
</style> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
< table border = "0" cellpadding = "0" cellspacing = "0" 
style= "align- content:center" > 
<tr> 
<td colspan = "3" style = "width:900px; height: 130px"> 
< img src = "images/top. jpg" style= "width: 100% ;" alt = 
</td> 
</tr> 
<tr> 
<td style = "background - image: url( 'images/edges. jpg');" 
class = "auto - stylel"> 
</td> 
<td class= "auto— style2"> 
<asp:ContentPlaceHolder ID = "ContentPlaceHolderl"”runat = " server"> 
</asp:ContentPlaceHolder > 
</td> 
<td style = "background - image: url('images/edges. jpg');" 
class = "auto - stylel"> 
</td> 
</tr> 
<tr style= "width:900px; height: 80px"> 
<td colspan= "3"> 
< img src = "images/bottom. jpg" style= "width: 100% ;" alt=""/> 
</td> 
</tr> 
</table> 
</div> 
</form> 
</body > 
</html > 


在 本 网 站 中 ,MasterPage. master 作为 Default. aspx、mamanermenu. aspx、studentmenu. 


aspx 和 teachermenu. aspx 等 网 页 的 母 版 页 ,这 样 能 够 达到 统一 网 页 设计 界面 的 目的 。 


欢迎 访问 本 教育 系统 


图 18. 9 MasterPage. master 设计 界面 
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18.4.2 主页 设计 


本 网 站 的 主页 是 Default. aspx, 它 提供 用 户 登录 ,其 设计 界面 如 图 18. 10 所 示 。 其 母 版 页 
为 MasterPage. master, 在 Contenl 中 包含 一 个 6X3 的 表格 ,表格 中 主要 有 用 户 编 号 文本 框 
TextBoxl、 密 码 文本 框 TextBox2、 用 户 类 型 单 选 按钮 (RadioButton1、RadioButton2 和 
RadioButton3) .输入 验证 码 文本 框 TextBox3、 显 示 验 证 码 标签 Labell、“ 登 录 ” 命 令 按 钮 
Button1“ 重 置 ”命令 按钮 Button2 和 * 看 不 清 ?命令 按钮 Button3。 

其 源 视图 代码 如 下 : 


<% @ Page Language = "C#" MasterPageFile= "~ /MasterPage. master" AutoEventWireup= 
CodeFile= "Default. aspx. cs" Inherits=" Default" 
Title= "欢迎 使 用 学 生成 绩 管 理 系 统 " StylesheetTheme = "Blue"” %> 
<asp:Content ID = "Content1" ContentPlaceHolderID = "ContentPlaceHolder1" 
Runat = "Server"> 
< link href = "App_Themes/StyleSheet. css" rel = "stylesheet" /> 
<table style = "width: 100% ; background- color: aliceblue" cellspacing:1"> 
<tr> 
<td colspan= "2" style= "text ~ align: center; height: 84px;"> 
< strong>< span style = "font - size: 24pt; color: 井 ff0033; 
font - family: 华文 新 魏 "> 用 户 登录 </span></strong> 


true" 


</td> 

</tr> 

<tr> 
<td class= "auto- stringstyle" style = "height: 20px"> 用 户 编号 </td> 
<td style= "width: 60 % ; height: 20px;"> 


<asp:TextBox ID = "TextBoxl”runat = "server" 
style = "width:135px"></asp:TextBox > 
Snbsp; 
<asp:RequiredFieldValidator ID= "RequiredFieldValidator1" 
runat = "server" ControlToValidate= "TextBox1" 
ErrorMessage = "用 户 编 号 不 能 为 空 "> </asp:RequiredFieldValidator> 
</td> 
</tr> 
<tr> 
<td class= "auto- stringstyle"> 密 gnbsp; 码 </td> 
<td style= "width: 60% ; height: 20px;"> 
<asp:TextBox ID = "TextBox2" runat = "server" textMode = "Password" 
style = "width:135px" ValidateRequestMode = "Enabled"></asp: TextBox > 
Snbsp; 
<asp:RequiredFieldValidator ID = "RequiredFieldValidator2" 
runat = "server" ControlToValidate = "TextBox2" 
ErrorMessage = "密码 不 能 为 空 " ></asp:RequiredFieldValidator> 
</td> 
</tr> 
< 
<td class= "auto- stringstyle"> 用 户 类 型 </td> 
<td style= "width: 60% ; height: 20px;"> 
<asp:RadioButton ID = "RadioButton1”runat = "server" 
Text = "学 生 " GroupName = "sel" /> 
gnbsp; &nbsp; 
<asp:RadioButton ID = "RadioButton2" runat = "server" 
Text = "教师 " GroupName = "sel" /> 
Snbsp; &nbsp; 
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<asp:RadioButton ID = "RadioButton3" runat = "server" 
Text = "管理 员 " GroupName = "sel" /> 
</td> 
</tr> 
<tr> 
<td class= "auto- stringstyle"> 输 入 验证 码 </td> 
<td style= "width: 60% ; height: 22px"> 
<asp:TextBox ID = "TextBox3" runat = "server" 
Width = "52px"></asp:TextBox> 
Snbsp; &nbsp; gnbsp; 
< strong>< span style = "color: 井 339966; font - family: 仿宋 ; 
font - size: medium;"> 验 证 码 : </span></strong> 
<asp:Label ID = "Label1" runat = "server" /> 
Snbsp; 
< span style = "font - family: 楷体 ; font - size: medium; color: 间 0000FF"> 
区 分 大 小 写 </span> 
<asp:Button ID= "Button3" runat = "server" 
OnClick = "Button3_Click" Text = "看 不 清 " 
style= "font — size: small;color:red;font — weight: bold;" /> 
</td> 
</tr> 
< 
<td colspan = "2" style= "text ~ align:center;height:56px"> 
<asp:Button ID = "Button1”runat = "server" 
Text = "登录 "OnClick = "Buttonl_Click" /> 
Snbsp; &nbsp; gnbsp; 
< input type = "reset" ID= "Button2" value = " 重 置 " 
class = "auto - resettyle" /> 
</td> 
</tr> 
</table> 
</asp:Content > 


用 户 登 录 


用 户 编号 [ 。” ”用 户 编号 不 能 为 空 


用 户 类 型 人 学生 人 教师 ne 
和 和 业主 表 验证 码 : [PRE 区 分 大 小 写 看 不 清 | 


EE 


@CopyRight By ABC 


图 18.10 主页 设计 界面 
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主页 对 应 的 部 分 类 代码 如 下 : 
public partial class Default : System. Web.UI. Page 
{ CommDB mydb = new CommDB(); // 公 共 字 段 
protected void Page_Load(object sender, EventArgs e) 
{ if (!Page. IsPostBack) 
Labell. Text = mydb.RandomNum(4); // 显 示 4 位 数 的 验证 码 
} 
protected void Buttonl1 _Click(object sender, EventArgs e) 
{ string mysql; 
int i; 
string uname = ""; 
if (TextBox3. Text. Trim() != Labell. Text. Trim()) // 验 证 码 输入 错误 


else 


{ if (RadioButton1.Checked) // 学 生 登 录 


{ mysql = "SELECT sname FROM student WHERE sno = 


+ 


Response. Write("< script > alert( ' 你 的 验证 码 输入 错误 ,请 重 输入 ! ')</script >"); 


TextBoxl. Text + "'AND spass = '" + TextBox2.Text + "'"; 


i = mydb.Rownum(mysql, "student", ref uname); 


if (i>0) // 合 法 用 户 
{ Session["uno"] = TextBoxl.Text.Trim(); // 保 存 学 号 
Session[ "uname"] = uname; // 保 存 姓名 


Server. Transfer("~ /studentmenu. aspx" ); 


和 


else // 非 法 用 户 


Response. Write("< script >alert( ' 对 不 起 ,' 


+ ' 你 输入 的 用 户 名 或 者 密码 错误 ,请 查实 ! ')</script >"); 


} 


else if (RadioButton2. Checked) // 教 师 登 录 


{ mysql = "SELECT tname FROM teacher WHERE tno = 


+ TextBoxl.Text + "'AND tpass = '" + TextBox2. Text + "mi 


i = mydb.Rownum(mysql, "teacher", ref uname); 


if (i>0) // 合 法 用 户 
{ ”Session["uno"] = TextBoxl.Text.Trim(); // 保 存 教师 编号 
Session[ "uname"] = uname; // 保 存 姓名 


Server. Transfer("™ /teachermenu. aspx" ); 


} 


else // 非 法 用 户 


Response. Write("< script >alert( ' 对 不 起 ,' + 


' 你 输入 的 用 户 名 或 者 密码 错误 , 请 查实 ! ')</script >"); 


} 
else if (RadioButton3. Checked) 


// 管 理 员 登 录 


{ mysql = "SELECT mname FROM manager WHERE mno = '" + TextBoxl. Text 


+ "'AND mpass = '" + TextBox2.Text + "'"; 
i = mydb.Rownum(mysql, "manager", ref uname); 


if (i>0) // 合 法 用 户 
{ ” Session["uno"] = TextBoxl.Text. Trim(); // 保 存 管理 员 编 号 
Session[ "uname"] = uname; // 保 存 姓名 
Server. Transfer("~ /managermenu. aspx" ); 
有 
else // 非 法 用 户 
Response.Write("< script >alert( ' 对 不 起 ,' + 
' 你 输入 的 用 户 名 或 者 密码 错误 ,请 查实 ! ')</script >"); 
3 
else // 没 有 选择 用 户 类 型 


Response. Write("< script > alert(' 对 不 起 , 必须 选择 用 户 类 型 ! ')</script >"); 
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} 
} 
protected void Button3_Click(object sender, EventArgs e) 
1 
Labell. Text = mydb. RandomNum(4); // 产 生 4 位 验证 码 
} 
} 


本 网 页 设计 中 使 用 Session("uno") 和 Session("uname") 保 存 用 户 的 登录 编号 (学 生 为 学 
号 、 教 师 为 教师 编号 ,管理 员 为 管理 员 编 号 ) 和 姓名 ,在 后 面 的 网 页 中 将 多 次 使 用 它们 。 

本 网 页 的 运行 界面 如 图 18. 11 所 示 。 在 用 户 输入 用 户 名 、 密 码 , 选 择 “ 学 生 ” “教师 ”或 “ 管 
理 员 ”用 户 类 型 并 输入 验证 码 登 录 后 ,分 别 进入 相应 的 操作 菜单 界面 。 


用 户 登 录 


01 


用 户 类 型 口 学 生 。 口 力 师 回 管 理 员 
输入 验证 马 [XWJP” 验证 西 。 8 区 分 大 小 要 


欢迎 访问 本 教育 系统 


copeny sc | 
图 18.11 主页 的 运行 界面 
18.4.3 管理 员 端 功能 设计 


提供 给 管理 员 的 操作 功能 有 学 生 信 息 管理 ,课程 信息 管理 .教师 信息 管理 ,管理 员 信 息 管 
理 , 安 排 课程 管理 ,学 生成 绩 管理 和 我 的 密码 管理 ,下 面 讨论 部 分 网 页 设计 。 

1. 管理 员 菜 单 网 页 managermenu. aspx 的 设计 

管理 员 菜单 网 页 为 managermenu. aspx, 其 设计 界面 如 图 18. 12 所 示 , 各 链接 指向 不 同 的 
网 页 以 实现 对 应 的 功能 。 其 母 版 页 为 MasterPage. master, 在 Contenl 中 包含 一 个 2X2 的 表 
格 ,第 1 行 有 一 个 Label 控件 Labell .在 第 2 行 第 1 列 中 有 一 个 TreeView 控件 TreeView1( 实 
现 菜单 的 功能 ) ,在 第 2 行 第 2 列 中 有 一 个 Iframe 框架 Iframel。 本 网 页 的 源 视图 代码 如 下 : 


<% @ Page Language = "C#" MasterPageFile= "~ /MasterPage. master" AutoEventWireup = "true" 
CodeFile = "managermenu. aspx. cs" Inherits = "managermenu" 
Title= "欢迎 使 用 学 生成 绩 管 理 系 统 "” StyleSheetTheme = "Blue” 先 > 
<asp:Content ID = "Content1" ContentPlaceHolderID = "ContentPlaceHolder1" 
Runat = "Server"> 
< link href = "App_Themes/StyleSheet. css" rel = "stylesheet" /> 
<table style = "width: 100% ; height: 55px;align - content:center;"> 
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<td colspan = "2" style= "height: 21px"> 


<asp:Label ID = "Labell" runat = "server"></asp:Label > 


</td> 
</tr> 


<td style= "width: 30% ; height: 400px; background - color: aliceblue"> 


<asp:TreeView ID = "TreeViewl" runat = "server" 
Font - Bold = "True" Font - Names = "仿宋 " Font - Size = "11pt"> 
<Nodes> 
<asp:TreeNode Text = "学 生 信 息 管理 ”Value = "学 生 信息 管理 " 
NavigateUrl = "~ /dispinfo.aspx?info = 欢迎 使 用 本 系统 " Target = "Iframel"> 
<asp:TreeNode NavigateUrl = "~ /Manager/addstudent. aspx" 
Target = "Iframel”Text = "添加 学 生 信息 ”Value = "添加 学 生 信息 "> 
</asp:TreeNode> 
<asp:TreeNode NavigateUrl = "~ /Manager/editstudent. aspx" 
Target = "Iframel" Text = "编辑 学 生 信息 ”Value = "编辑 学 生 信 息 "> 
</asp:TreeNode> 
</asp:TreeNode> 
<asp:TreeNode Text = "课程 信息 管理 ”Value = "课程 信息 管理 " 
NavigateUrl = "~ /dispinfo.aspx?info = 欢迎 使 用 本 系统 " Target = "Iframel"> 
<asp:TreeNode NavigateUrl = "~ /Manager/addcourse.aspx" Target = "Iframel" 
Text = "添加 课程 信息 ”Value = "添加 课程 信息 "> 
</asp:TreeNode > 
<asp:TreeNode Text = "编辑 课程 信息 ”Value = "编辑 课程 
NavigateUrl = "~ /Manager/editcourse. aspx" Target = "Iframel"> 
</asp:TreeNode > 
</asp:TreeNode> 
<asp:TreeNode Text = "教师 信息 管理 ”Value = "教师 信息 管理 " 
NavigateUrl = "~ /dispinfo.aspx?info = 欢迎 使 用 本 系统 " Target = "Iframel"> 
<asp:TreeNode NavigateUrl = "~ /Manager/addteacher. aspx" 
Target = "Iframel”Text = "添加 教师 信息 ”Value = "添加 教师 信息 "> 
</asp:TreeNode> 
<asp:TreeNode Text = "编辑 教师 信息 " Value = "编辑 教师 信息 " 
NavigateUrl = "~ /Manager/editteacher. aspx" Target = "Iframel"> 
</asp:TreeNode> 
</asp:TreeNode> 
<asp:TreeNode Text = "管理 员 信息 管理 ”Value = "管理 员 信 息 管理 ” 
NavigateUrl = "~ /dispinfo.aspx?info = 欢迎 使 用 本 系统 " Target = "Iframel"> 
<asp:TreeNode Text = "添加 管理 员 信息 ”Value = "添加 管理 员 信息 ” 
Target = "Iframel" NavigateUrl = "~ /Manager/addmanager. aspx"> 
</asp:TreeNode > 
<asp:TreeNode Text = "编辑 管理 员 信 息 ”Value = "编辑 管理 员 信息 " 
Target = "Iframel" NavigateUr]l = "~ /Manager/editmanager. aspx"> 
</asp:TreeNode > 
</asp:TreeNode> 
<asp:TreeNode Text = "安排 课程 管理 " Value = "安排 课程 管理 " 
NavigateUrl = "~ /dispinfo.aspx?info = 欢迎 使 用 本 系统 " Target = "Iframel"> 
<asp:TreeNode Text = "安排 课程 任课 教师 ”Value = "安排 课程 任课 教师 ” 
Target = "Iframel" NavigateUrl = "~ /Manager/plancourse. aspx"> 
</asp:TreeNode > 
</asp:TreeNode> 
<asp:TreeNode Text = "学 生成 绩 管理 " Value = "学 生成 绩 管理 " 
NavigateUrl = "~ /dispinfo.aspx?info = 欢迎 使 用 本 系统 " Target = "Iframel"> 
<asp:TreeNode Text = "查询 学 生成 绩 " Value = "查询 学 生成 绩 " 
Target = "Iframel" NavigateUrl = "~ /Manager/queryallscore. aspx"> 
</asp:TreeNode > 
</asp:TreeNode> 


481 


482 
SP.NET 4. 5 动态 网 站 设计 教程 一 一 基于 C# 5.0 十 SQL Server 2012 


<asp:TreeNode Text = "我 的 密码 管理 ”Value = "我 的 密码 管理 " 
NavigateUrl = "~ /dispinfo.aspx?info = 欢迎 使 用 本 系统 " Target = "Iframel"> 
<asp:TreeNode Text = "更 改 我 的 密码 " Value = "更 改 我 的 密码 " 
Target = "Iframel" NavigateUr]l = "~ /Manager/updatemanagerpass. aspx"> 
</asp:TreeNode> 
</asp:TreeNode> 
</Nodes > 
</asp:TreeView> 
<asp:HyperLink ID = "HYperLinkl" runat = "server" style= "font - family: 黑 体 ; 
font - weight: bold;font - size:16pxicolor: 井 009900" 
NavigateUrl = "~ /Default.aspx" Target= "_self"> 退 出 本 系统 </asp:HyperLink> 
</td> 
<td style= "width: 99 % ; height: 400px"> 
< iframe id= "Iframel" name= "Iframel"src= "dispinfo.aspx?info= 欢迎 使 用 本 系统 " 
style = "width: 99 % ; height: 99% "></iframe> 
</td> 
</tr> 
</table> 
</asp:Content > 


学 生成 岳 管 理 系统 


日 掌 生 信息 管理 
添加 掌 生 信 息 
篇 辑 学 生 信息 
电 诬 程 信息 管理 
添加 课程 信息 
Ee hopJhecalhest.4923sjdispinle.aspctinle= 政 途 合 用 本 系统 
至 加 教师 信息 
篇 辑 教师 信息 
日 管理 员 信 息 管 理 
漂 加 管理 商 信 息 
编辑 管理 员 信 息 
日 安排 详 程 管理 
实 排灌 程 任 谨 教 师 
日 学 生成 绩 管 理 
查询 掌 生成 针 
日 我 的 寓 号 管理 
更 改 我 的 窗 码 
退出 本 系统 


图 18. 12 managermenu. aspx 网 页 设计 界面 


在 上 述 代码 中 ,TreeView1l 控件 的 各 结 点 用 作 菜 单项 ,叶子 菜单 项 链接 到 实际 功能 的 网 
页 , 非 叶子 菜单 项 链接 到 通用 dispinfo. aspx 网 页 ,仅仅 显示 提示 信息 。 所 有 菜单 项 对 应 的 
NavigateUrl 属性 如 下 。 

。 学 生 信息 管理 : 一 /dispinfo. aspx?info 王 欢迎 使 用 本 系统 

。 添加 学 生 信 息 : 一 /Manager/addstudent. aspx 

。 编辑 学 生 信 息 : 一 /Manager/editstudent. aspx 

。 课程 信息 管理 : 一 /dispinfo. aspx?info 王 欢迎 使 用 本 系统 

。 添加 课程 信息 : 一 /Manager/addcourse. aspx 

。 编辑 课程 信息 : 一 /Manager/editcourse. aspx 

。 教师 信息 管理 : /dispinfo. aspx?info 一 欢迎 使 用 本 系统 
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。 添加 教师 信息 : 一 /Manager/addteacher. aspx 

。 编辑 教师 信息 : 一 /Manager/editteacher. aspx 

。 管理 员 信息 管理 : 一 /dispinfo. aspx?info 一 欢迎 使 用 本 系统 

。 添加 管理 员 信息 : 一 /Manager/addmanager. aspx 

。 编辑 管理 员 信息 : 一 /Manager/editmanager. aspx 

。 安排 课程 管理 : 一 /dispinfo. aspx?info 一 欢迎 使 用 本 系统 

。 安排 课程 任课 教师 : 一 /Manager/plancourse. aspx 

。 学 生成 绩 管理 : ~/dispinfo. aspx?info 王 欢迎 使 用 本 系统 

。 查询 学 生成 绩 : 一 /Manager/queryallscore. aspx 

它们 的 Target 均 为 Iframel ,在 运行 时 ,用 户 单 击 某 个 结 点 时 会 转向 相应 的 网 页 去 执行 ， 
但 不 是 在 新 窗口 中 执行 ,而 是 在 Iframel 框架 中 执行 , 除 Iramel 框架 中 的 内 容 外 ,其 他 部 分 不 
刷新 ,这 种 设计 不 仅 提高 了 网 络 的 传输 速度 ,而 且 减少 了 整个 屏幕 的 刷新 次 数 。 

在 本 网 页 上 设计 如 下 事件 过 程 : 


protected void Page Load( object sender, EventArgs e) 
{ 
Labell. Text = "管理 员 端 一 欢迎 你 :”+ Session["uname"] + "(" + Session["uno"] + ")"; 

} 

其 功能 是 在 表格 第 1 行 中 显示 登录 的 用 户 姓名 和 用 户 编号 ,其 数据 源 来 自 Default aspx 
网 页 中 保存 的 会 话 数据 

例如 ,管理 员 用 户 901/ 刘 丹 登录 后 的 管理 员 界 面 如 图 18. 13 所 示 。 在 该 界面 中 可 以 完成 
一 系列 管理 员 的 工作 。 


驳 之 人 召 用 再 素 琉 


图 18.13 管理 员 用 户 界面 
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2. 学 生 信 息 管理 
学 生 信息 管理 有 添加 学 生 信息 和 编辑 学 生 信息 两 项 功能 。 
1) 添加 学 生 信 息 网 页 设计 


添加 学 生 信 息 的 网 页 是 addstudent. EECE3 
aspx, 其 设计 界面 如 图 18. 14 所 示 ,包括 一 个 
7X3 的 表格 ,表格 中 主要 有 学 号 文本 框 
TextBoxl、 姓 名 文本 框 TextBox2、 性 别 单 选 
按钮 (RadioButton1 和 RadioButton2)、 民 族 
下 拉 列 表 框 DropDownListl、 班 号 文本 框 
TextBox3、“ 提 交 ” 命 令 按钮 Button1、“ 重 置 ” 
按钮 Resetl(type 属性 为 “reset”) , 另 有 两 个 


验证 控件 用 于 检测 不 能 输入 空 的 学 号 和 


姓名 。 


18.14 addstudent, aspx 设计 界面 


在 该 网 页 上 设计 如 下 事件 过 程 : 
Protected void Button1_Click(object sender, EventArgs e) 


{ 


} 


int i; 
CommDB mydb = new CommDB(); 
string mysql, sn = ""; 
mysql = "SELECT * FROM student WHERE sno='" + TextBoxl.Text + "'"; 
i = mydb. Rownum(mysql, "student", ref sn); 
if (i>0) 
Response. Redirect("~ /dispinfo. aspx? info = 学 号 重复 ,不 能 添加 该 学 生 记 录 !"); 
else 
{ string xb; 
if (RadioButton1. Checked) 
xb = " 男 "; 
else if (RadioButton2.Checked) 
xb = " 女 "; 
else 
动 -= nm 
mysql = "INSERT INTO student( sno, sname, ssex, snation, sclass, spass) " + 
"VALUES( "TextBox1. Text + "','" + TextBox2.Text + "wm +xb+","t+ 
DropDownList1. SelectedValue + "','" + TextBox3.Text + "'," + 
TextBoxl1. Text + "')"; 
mydb. ExecuteNonQuery(mysql1); ; 
Response. Redirect("~ /dispinfo. aspx?info= 学生 记录 已 成 功 添加 !"); 


在 用 户 单 击 Buttonl( 提 交 ) 后 , 先 检查 学 号 是 否 重复 , 若 不 重复 , 则 将 其 插入 到 student 


表 中 。 


例如 ,管理 员 添 加 一 个 学 号 为 580 的 学 生 记录 的 操作 界面 如 图 18. 15 所 示 , 单 击 “提交 ” 命 
令 按 钮 将 该 记录 插入 到 student 表 ; 单 击 * 重 置 "命令 按钮 表示 重新 输入 。 

2) 编辑 学 生 信息 网 页 设计 

编辑 学 生 信息 网 页 有 3 个 ,editstudent. aspx 用 于 输入 查询 条 件 ,editstudentl. aspx 用 于 
显示 所 有 满足 查询 条 件 的 学 生 记录 ,editstudent2. aspx 用 于 修改 指定 的 单个 学 生 记录 。 


图 18.15 添加 一 个 学 生 记录 


(1) editstudent. aspx 网 页 设计 
该 网 页 用 于 输入 查找 条 件 , 其 设计 界面 
如 图 18. 16 所 示 , 其 中 包括 一 个 7X2 的 表格 ， 
表格 中 主要 有 学 号 文本 框 TextBoxl、 姓 名 文 
本 框 TextBox2 性别 单 选 按钮 (RadioButtonl 
和 RadioButton2)、 民 族 文本 框 TextBox3 、 班 
号 文本 框 TextBox4、 “提交 ” 命 令 按 钮 
Button1“ 重 置 " 按 钮 Button2(type 属性 为 
“reset”) 。 
当 用 户 没 有 输入 任务 内 容 时 ,表示 查找 国 8: 的， 衣 iemdinc nal 汪 禄 神 关 而 
所 有 学 生 记录 。 
在 该 网 页 上 设计 如 下 事件 过 程 : 
Protected void Button1_Click(object sender, EventArgs e) 
{ string condstr = "",xb,mysql; 
// 以 下 代码 用 于 构造 条 件 表达 式 condstr 
if (TextBoxl. Text != "") 
condstr = "sno Like '" + TextBoxl.Text + "要 "7 
if (TextBox2. Text != "") 
if (condstr == "") 
condstr = "sname Like '" + TextBox2.Text + "S$%S"™"; 
else 
condstr = condstr + " AND sname Like '" + TextBox2.Text + "% '"™; 
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} 


if (RadioButton1. Checked) 


xb =“" 男 "; 

else if (RadioButton2.Checked) 
xb =" 女 "; 

else 
Wa 

if (xb != "") 


if (condstr=="") 
condstr = "ssex='"" + xb+ ""; 
else 
condstr = condstr + "RND ssex='" + xb+ ""; 
if (TextBox3. Text != "") 
if (condstr == "" 
condstr = "snation LIKE '" + TextBox3.Text + "%"™"; 
else 
condstr = condstr + " AND snation LIKE '" + TextBox3.Text + "%'"; 
if (TextBox4. Text != "") 
if (condstr == "") 
condstr = "sclass LIKE '" + TextBox4.Text + "%S'"; 
else 
condstr = condstr + " AND sclass LIKE '" + TextBox4.Text + "$%'"; 
if (condstr == "") 
mysql = "SELECT * FROM student ORDER BY sno"; 
else 
mysql = "SELECT * FROM student WHERE "+ condstr + "ORDER BY sno"; 
Session["sql"] = mysql; // 用 会 话 保存 SQL 语句 
Response. Redirect("editstudent1.aspx"); 


(2) editstudentl. aspx 网 页 设计 

该 网 页 用 于 输入 查找 条 件 , 其 设计 界面 如 图 18. 17 所 示 ,其 中 包括 一 个 3X1 的 表格 ,第 1 
行 包括 一 个 HTML 标签 ,第 2 行 包括 一 个 GridView 控件 GridViewl ,第 3 行 包括 一 个 命令 按 
钮 Buttonl 。 


18.17 editstudentl. aspx 设计 界面 


当 用 户 单 击 某 行 的 “编辑 ” 超 链接 时 进入 该 记录 的 编辑 状态 , 单 击 某 行 的 “删除 ” 超 链 接 时 
便 可 删除 该 记录 。 
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该 网 页 的 逻辑 代码 如 下 : 
public partial class editstudentl1 : System. Web. UI.Page 
{ string mysql7 
CommDB mydb = new CommDB(); 
DataSet myds = new DataSet(); 
protected void Page_Load(object sender, EventArgs e) 
{ if (!Page.IsPostBack) 
{ bind(); } 
} 
protected void GridViewl PageIndexChanging(object sender,GridViewPageEventArgs e) 
{ // 分 页 
GridView1.PageIndex = e.NewPageIndex; 
bind(); 
} 
protected void GridViewl RowEditing(object sender, GridViewEditEventArgs e) 
{ // 编 辑 记 录 
string sno = GridView1.DataKeys[e.NewEditIndex]. Value.ToString(); 
Response. Redirect("editstudent2. aspx?sno= ”+ sno); 
protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e) 
{ 。 // 删 除 记录 
string sno = GridView1.DataKeys[e.RowIndex].Value. ToString(); 
string mysql; 
mysql = "DELETE FROM student WHERE sno='" + sno + ""™; 
mydb. ExecuteNonQuery( mysql); 
bind(); 
} 
public void bind( ) // 自 定义 方法 ,用 于 绑 定 Gridviewl 控件 的 数据 


{ mysql = Session["sql"].ToString(); 
myds = mydb.ExecuteQuery(mysql, "student"); 
GridView1.DataSource = myds.Tables["student"]; 
GridViewl.DataKeyNames = new string[] { "sno" }; 
GridView1.DataBind( ); 


} 
protected void Buttonl_Click(object sender, EventArgs e) 
{ 
Response. Redirect("~ /dispinfo. aspx?info = 学 生 记 录 编 辑 完 毕 !"); 
} 


} 
(3) editstudent2. aspx 网 页 设计 


该 网 页 用 于 修改 指定 的 学 生 记录 ,其 设计 界面 如 图 18. 18 所 示 , 其 中 包括 一 个 7X2 的 表 
格 ,表格 中 主要 有 学 号 文本 框 TextBoxl 、 姓 名 文本 框 TextBox2、 性 别 单 选 按钮 (RadioButtonl 
和 RadioButton2) .民族 文本 框 TextBox3 、 班 号 文本 框 TextBox4“ 提 交 ” 命 令 按 钮 Buttonl 、 


“ 重 置 ”按钮 Button2(type 属性 为 “reset”) 。 
该 网 页 的 逻辑 代码 如 下 : 
public partial class editstudent2 : System. Web. UI. Page 
{ CommDB mydb = new CommDB(); 


string mysql; 
protected void Page Load(object sender, EventArgs e) 
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i if (!Page. IsPostBack) 
{ DataSet myds = new DataSet(); 

string sno = Request. QueryString["sno"]; 
mysql = "SELECT x FROM student WHERE sno='"" + sno + "'"; 
myds = mydb.ExecuteQuery(mysql, "student"); 
DataRow mydr = myds.Tables["student"].Rows[0]; 
TextBoxl1. Text = mydr["sno"].ToString(); 
TextBox2. Text = mydr["sname"].ToString(); 
string xb = mydr["ssex"].ToString(); 
f(xb == " 男 ") 

RadioButton1. Checked = true; 
else if (xb == " 女 ") 

RadioButton2. Checked = true; 
DropDownList1.Text = mydr["snation"].ToString(); 
TextBox3. Text = mydr["sclass"].ToString(); 


1 


} 
} 
protected void Button1_Click(object sender, EventArgs e) 


{ string xb; 

if (RadioButton1. Checked) 
xb = " 男 "; 

else if (RadioButton2.Checked) 
xb = " 女 "; 

else 
xb = "ni 

mysql = "UPDATE student SET sname = '" + TextBox2.Text + "',ssex = "+ 
xb +"',snation='" + DropDownList1. SelectedValue + "',sclass = "+ 


TextBox3. Text + "'WHERE sno='" + TextBoxl.Text + """; 
mydb. ExecuteNonQuery( mysql); 
Response. Redirect("editstudent1. aspx" ); 


图 18.18 ”editstudent2. aspx 设计 界面 


例如 ,管理 员 编 辑 学 号 为 580 的 学 生 记 录 的 过 程 如 图 18. 19 所 示 , 这 3 个 界面 分 别 对 应 
editstudent. aspx、editstudentl. aspx 和 editstudent2. aspx 网 页 。 

“课程 信息 管理 ”“ 教 师 信 息 管理 ”“ 管 理 员 信息 管理 ”和 “我 的 密码 管理 ”模块 的 功能 与 操 
作 和 “学 生 信 息 管理 ”模块 的 功能 与 操作 相似 ,这 里 不 再 介绍 。 

3. 安排 课程 管理 功能 设计 

安排 课程 管理 功能 由 plancourse. aspx 和 plancoursel. aspx 两 个 网 页 实现 。 
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单 击 “ 确 定 "按钮 


选择 * 男 "作为 查找 条 件 
选择 学 号 为 580 的 


修改 学 生 记录 并 单 击 "提交 ”按钮 
18.19 管理 员 编 辑 一 个 学 生 记录 的 过 程 


(1) plancourse. aspx 网 页 设计 
该 网 页 的 设计 界面 如 图 18. 20 所 示 ,其 中 包含 一 个 HTML 文字 ,一 个 Labell 标签 ,一 个 
GridViewl 控件 和 一 个 Buttonl 命令 按钮 。GridView1l 控件 的 源 视图 代码 如 下 : 


<asp:GridView ID = "GridViewl" runat = "server" AllowPaging = "True" 
RutoGenerateColumns = "False" BackColor = "LightGoldenrodYellow" 
BorderColor = "Tan" BorderWidth= "lpx" CellPadding = "2" 
Font ~ Bold = "True" Font - Size= "10pt" ForeColor = "Black" GridLines = "None" 
OnPageIndexChanging = "GridViewl_PageIndexChanging" 
OnRowEditing = "GridViewl_ RowEditing" Width = "493px"> 
< FooterStyle BackColor = "Tan" /> 
<Columns> 
<asp:BoundField DataField = "cno”HeaderText = "课程 号 "> 
< ItemStyle HorizontalAlign= "Center" /> 
</asp:BoundField> 
<asp:BoundField DataField = "cname”HeaderText = "课程 名 "> 
< ItemStyle HorizontalAlign= "Center" /> 
</asp:BoundField> 
<asp:BoundField DataField = "ctime"” HeaderText = "上 课 学 期 "> 
< ItemStyle HorizontalAlign= "Center" /> 
</asp:BoundField> 
<asp:BoundField DataField = "cplace"” HeaderText = "上课 地 点 "> 
< ItemStyle HorizontalAlign= "Center" /> 
</asp:BoundField> 
<asp:BoundField DataField = "tno”HeaderText = "上课 教师 编号 "> 
< ItemStyle HorizontalAlign= "Center" /> 
</asp:BoundField> 
<asp:BoundField DataField = "tname”HeaderText = "上课 教师 "> 
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< ItemStyle HorizontalAlign= "Center" /> 
</asp:BoundField> 
<asp:CommandField HeaderText = "操作 ”ShowEditButton = "True" 
EditText = "安排 /更 改 教师 "> 
< ItemStyle ForeColor = "Blue" HorizontalAlign = "Center" /> 
</asp:CommandField> 
</Columns> 
< SelectedRowStyle BackColor = "DarkSlateBlue" ForeColor = "GhostWhite"” /> 
< PagerStyle BackColor = "PaleGoldenrod" ForeColor = "DarkSlateBlue" 
HorizontalAlign= "Center" /> 
< HeaderStyle BackColor = "Tan" Font - Bold= "True"” /> 
<AlternatingRowStyle BackColor = "PaleGoldenrod" /> 
</asp:GridView > 


数据 绑 定 安排 / 更改 教师 
| 数据 绑 定 安排 /更 改 教师 
|| 数据 绑 定 数据 绑 定 数据 绑 定 数据 绑 定 数据 绑 定 安排 / 更改 教师 | 


| 数据 绑 定 数据 绑 定 数据 绑 定 数据 绑 定 
|| 数据 绑 定 孝 据 绑 定 数据 绑 定 数据 乡 定 
数据 绑 定 教 据 螂 定 数据 绑 定 数据 绑 定 
数据 绑 定 教 据 绑 定 数据 绑 定 教 据 绑 定 
数据 绑 定 数据 绑 定 数据 绑 定 数据 绑 定 
数据 绑 定 数据 绑 定 数据 敌 定 数据 绑 定 

| 数据 绑 定 数据 绑 定 数据 铸 定 数据 绑 定 
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退出 课程 安排 


图 18. 20 ”plancourse. aspx 网 页 设计 界面 


本 网 页 的 程序 代码 如 下 : 


using System; 
using System. Data; 
using System. Web. UI; 
using System. Web. UI. WebControls; 
public partial class plancoursel : System. Web.UI.Page 
{ stringmysql; 
CommDB mydb = new CommDB(); 
DataSet myds = new DataSet(); 
protected void Page_Load(object sender, EventArgs e) 
{ if (!Page. IsPostBack) 
{ string cname = Request.QueryString["cname"]; 
Labell.Text = "(" + cname + ")"; 
bind(); 


} 
protected void GridView]l RowEditing(object sender, GridViewEditEventArgs e) 
i // 编 辑 记 录 
string tno = GridViewl.DataKeys[e.NewEditIndex][0].ToString(); 
// 获 取 当 前 行 的 tno 值 
string tname = GridViewl.DataKeys[e.NewEditIndex][1].ToString(); 
// 获 取 当 前 行 的 tname 值 
string cno = Request. QueryString[ "cno"]; 


} 


mysql = "UPDATE course SET tno='" + tno + "',tname='" 十 
tname + "'WHERE cno= "+ cno + "7 

mydb. ExecuteNonQuery( mysql); 

Response. Redirect("plancourse. aspx" ); 


} 
protected void GridViewl PageIndexChanging(object sender, GridViewPageEventArgs e) 
‘ // 分 页 
GridView1.PageIndex = e.NewPageIndex; 
bind(); 


} 

public void bind() 

{ mysql = "SELECT * FROM teacher"; 
myds = mydb.ExecuteQuery(mysql, "teacher"); 
GridView1.DataSource = myds.Tables["teacher"]; 
GridView1.DataKeyNames = new string[] { "tno","tname" }; 
GridView1.DataBind( ); 


GridViewl 控件 中 的 前 6 列 显示 课程 的 信息 ,每 门 课程 为 一 行 ,而 “安排 /更 改 教师 ”链接 
用 于 安排 或 更 改 该 行 课程 的 任课 教师 。 

(2) plancoursel. aspx 网 页 设计 

该 网 页 的 设计 界面 如 图 18. 21 所 示 ,其 中 包含 一 个 HTML 文字 ,一 个 Labell 标签 和 一 个 
GridViewl 控件 。 其 程序 代码 如 下 : 

using System; 

using System. Data; 

using System. Web. UI; 


using System. Web. UI. WebControls; 
public partial class plancoursel : System. Web.UI. Page 


{ 


string mysql; 
CommDB mydb = new CommDB(); 
DataSet myds = new DataSet(); 
protected void Page_Load(object sender, EventArgs e) 
{ if (!Page.IsPostBack) 
{ string cname = Request.QueryString["cname"]; 
Labell.Text = "(" + cname + ")"; 
bind(); 
} 
} 
protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e) 
{ // 编 辑 记 录 
string tno = GridViewl.DataKeys[e. NewEditIndex][0].ToString(); // 获 取 当 前 行 的 tno 值 
string tname = GridViewl.DataKeys[e. NewEditIndex][1]. Tostring(); // 获 取 当 前 行 的 tname 值 
string cno = Request. QueryString[ "cno"]; 
mysql = "UPDATE course SET tno='" + tno + "',tname='" 十 
tname + "'WHERE cno= "+ cno + "™; 
mydb. ExecuteNonQuery( mysql); 
Response. Redirect("plancourse. aspx" ); 
} 
protected void GridViewl PageIndexChanging(object sender, GridViewPageEventArgs e) 
{ // 分 页 
GridView1.PageIndex = e.NewPageIndex; 
bind(); 
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public void bind() 

{ mysql = "SELECT x* FROM teacher"; 
myds = mydb.ExecuteQuery(mysql, "teacher"); 
GridView1.DataSource = myds.Tables["teacher"]; 
GridView1.DataKeyNames = new string[] { "tno","tname" }; 
GridView1.DataBind( ); 


} 

GridViewl 控件 中 的 前 4 列 显示 教师 的 信息 ,每 个 教师 为 一 行 ,而 “选择 ”链接 用 于 指定 该 
教师 为 前 面 所 选课 程 的 任课 教师 。 

例如 ,管理 员 901 将 “计算 机 导论 ”课程 任课 教师 由 “ 李 郎 ”更 改 为 * 刘 冰 ” 的 过 程 如 图 18. 22 
所 示 , 这 两 个 界面 分 别 对 应 plancourse. aspx 和 plancoursel. aspx 网 页 。 


图 18.21 plancoursel. aspx 网 页 设计 界面 图 18.22 更 改 任 课 教 师 的 操作 过 程 


4. 学 生成 绩 管理 功能 设计 

学 生成 绩 管理 功能 由 queryallscore. aspx 和 queryallscorel. aspx 两 个 网 页 实现 。 

(1) queryallscore. aspx 网 页 设计 

该 网 页 用 于 设置 查询 学 生 的 条 件 , 其 设计 界面 如 图 18. 23 所 示 , 其 中 包含 5 个 HTML 文 
字 、4 个 文本 框 (TextBoxl 一 TextBox4)., 一 个 “提交 ”命令 按钮 Buttonl 和 一 个 “ 重 置 ”按钮 
Button2(type 属性 为 “reset”) 。 在 该 网 页 上 设计 如 下 事件 处 理 过 程 ， 


protected void Button1l_Cl ick(object sender, EventArgs e) 
{ string condstr = "",mysql; 
// 以 下 构造 条 件 表达 式 condstr 
if (TextBoxl1. Text != "") 
condstr = "sno Like '" + TextBox1.Text + "于 "7 
if (TextBox2. Text != "") 
if (condstr == "") 
condstr = "sname Like '" + TextBox2.Text + "%S'"; 
else 
condstr = condstr + ”RND sname Like '" + TextBox2.Text + "% '"; 
if (TextBox3. Text != "") 
if (condstr == "") 
condstr = "cno LIKE '" + TextBox3.Text + "S$%'"; 
else 
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condstr = condstr + " AND cno LIKE '" + TextBox3.Text + "$%'"; 
if (TextBox4. Text != "") 
if (condstr == "") 
condstr = "cname LIKE '" + TextBox4.Text + "%"™; 
else 
condstr = condstr + " AND cname LIKE '" + TextBox4.Text + "% '"; 
if (condstr == "") 
mysql = "SELECT * FROM score"; 
else 
mysql = "SELECT * FROM score WHERE " + condstr; 
Response. Redirect("queryallscorel.aspx?mysql =" + mysql); 
} 


用 户 设置 查询 条 件 后 单 击 “ 确 定 ” 命 令 按 钮 时 转向 queryallscorel. aspx 网 页 。 

(2) queryallscorel. aspx 网 页 设计 

该 网 页 用 于 显示 满足 查询 条 件 的 学 生成 绩 , 其 设计 界面 如 图 18. 24 所 示 , 其 中 包含 一 个 HTML 
文字 一 个 Buttonl 命令 按钮 和 一 个 GridViewl 控件 。 在 该 网 页 上 设计 如 下 事件 处 理 过 程 : 


protected void Page_Load( object sender, EventArgs e) 
{ if (!Page.IsPostBack) 
bind(); 
} 
protected void GridViewl_PageIndexChanging( object sender, GridViewPageEventArgs e) 
{ /分 页 
GridView1. PageIndex = e.NewPageIndex; 
bind(); 
} 
public void bind() 
{ CommDB mydb = new CommDB(); 
string mysql = Request. QueryString["mysql"]; 
DataSet myds = new DataSet(); 
myds = mydb. ExecuteQuery(mysql, "score"); 
GridView1. DataSource = myds.Tables["score"]; 
GridView1. DataKeyNames = new string[] { "sno" }; 
GridView1. DataBind(); 
} 
protected void Button1l_Cl ick(object sender, EventArgs e) 
{ 


; 


Response. Redirect("~ /dispinfo.aspx?info = 学 生成 绩 查看 完毕 !"); 


| 数据 绑 定 数据 做 定 数据 绑 定 教 据 娘 定 数据 娃 定 数据 绑 定 | 
“数据 绑 定 数据 狠 定 数据 绪 定 教 据 姥 定 数据 饰 定 数据 铸 定 
| 数据 绑 定 数据 姥 定 数据 铸 定 数据 铸 定 数据 绑 定 数据 绑 定 


数据 绑 定 数据 铸 定 教 据 绑 定 孝 据 绑 定 数据 绑 定 
站 各 
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例如 ,管理 员 901 查看 选修 301 课程 学 生成 绩 的 过 程 如 图 18. 25 所 示 , 这 两 个 界面 分 别 对 
应 queryallscore. aspx 和 queryallscorel. aspx 网 页 。 


指定 查找 条 件 为 301 课 程 


单 击 “确定 "按钮 101” 李 军 。 01 计算 机 导论 
102 陆 力 301 计算 机 导论 
103 区 明 。 301 计算 机 导论 


Li 查找 | 


18.25 更 改 任课 教师 的 操作 过 程 


18.4.4 学 生 端 功能 设计 


学 生 端 功能 设计 与 管理 员 端 功能 设计 相似 ,由 同学 们 上 机 完成 ,其 主要 功能 有 选课 管理 、 
成 绩 管 理 和 密码 管理 。 
例如 ,学 号 为 580 的 学 生 登 录 后 显示 界面 如 图 18. 26 所 示 。 


| 3 D8 pyeconoreeozopcpahrr 


日 选课 管 


[ 颈 迎 使 用 三 系 吏 


日 密码 管理 
更 改 我 的 密码 
退出 本 系统 


| 驳 迎 访问 本 教育 系统 | 
TL 


图 18.26 学 生 用 户 界面 


学 号 为 580 的 学 生 单 击 “ 选 修 课程 /取消 课程 ”, 出现 所 有 课程 的 网 页 界面 ,可 以 单 击 “ 选 
修 " 或 “取消 "命令 按钮 实现 该 行 课程 的 选修 或 取消 ,图 18. 27 所 示 的 是 该 学 生 选 修了 两 门 课程 
( 带 V 的 课程 表示 已 选 , 带 X 的 课程 表示 没有 选 )。 

注意 : 一 旦 单 击 了 “提交 选修 课程 ”按钮 ,该 学 生 不 能 再 进入 本 界面 。 
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图 18.27 学 生 选修 或 取消 课程 界面 


例如 ,学 号 为 101 的 学 生 登 录 后 单 击 * 列 我 的 成 绩 单 ” 出 现 该 学 生 所 有 课程 的 成 绩 , 如 
图 18. 28 所 示 。 


图 18.28 列 我 的 成 绩 单 界面 


18.4.5 教师 端 功能 设计 


教师 端 功 能 设计 与 管理 员 端 功能 设计 相似 ,由 同学 们 上 机 完成 ,其 主要 功能 有 提供 课程 管 
理 、 成 绩 管 理 和 密码 管理 。 
例如 ,编号 为 801 的 教师 登录 后 显示 界面 如 图 18. 29 所 示 。 


葡 巡 促 用 在 系统 


区 和 
退出 本 系统 


| 


图 18.29 教师 用 户 界面 


495 


496 
P.NET 4.5 动态 网 站 设计 教程 一 一 基于 C# 5. 0 十 SQL Server 2012 


例如 ,编号 为 801 的 教师 单 击 “ 查 看 选课 学 生 ”, 出 现 所 有 课程 的 网 页 界面 ,选择 一 门 课程 
后 单 击 “ 确 定 ” 命 令 按 钮 即 显示 所 有 选修 该 课程 的 学 生 信息 ,如 图 18. 30 所 示 。 


图 18.30 教师 查看 选修 某 课程 的 学 生 


例如 ,编号 为 801 的 教师 单 击 “ 输 入 学 生成 绩 ”, 出 现 所 有 课程 的 网 页 界面 ,选择 一 门 课程 
后 单 击 “ 确 定 ” 命 令 按钮 ,进入 成 绩 输 入 界面 ,教师 可 以 一 次 输入 或 修改 所 有 学 生 的 成 绩 , 如 
图 18. 31 所 示 , 单 击 “ 保 存 成 绩 ” 命 令 按钮 时 将 成 绩 保存 在 StudDB 数据 库 中 。 


单 击 “ 确 定 " 按 钮 
Em (CH Se 
选择 课程 
图 18.31 教师 输入 成 绩 的 过 程 
练习 题 18 


. 简 述 用 ASP.NET 十 C# 十 SQL Server 开发 Web 系统 的 过 程 。 

. 在 学 生成 绩 管理 网 站 中 为 什么 设计 通用 类 CommDB. cs? 

. 在 学 生成 绩 管理 网 站 中 为 什么 设计 StyleSheet. css 样式 文件 ? 

. 在 学 生成 绩 管理 网 站 中 为 什么 设计 SkinFile. skin 皮肤 文件 ? 

. 在 学 生成 绩 管理 网 站 中 为 什么 设计 MasterPage. master 母 版 页 ? 


上 机 实验 题 18 


完成 学 生成 绩 管理 网 站 的 学 生 端 功能 设计 和 教师 端 功 能 设计 。 


am oo 


APPENDIX 


上 机 实验 题 设计 参考 答案 ” 附录 A 


上 机 实验 题 1 


设计 步骤 如 下 : 
@ 在 chl 网 站 中 添加 一 个 Expermentl 网 页 (采用 代码 隐藏 页 模型 )。 
@ 其 源 视 图 代码 如 下 : 


<$% @ Page Language= "C#" AutogventWireup = "true" CodeFile = "Experment1.aspx.cs" 
Inherits = "Experment1l" %> 
<html xmlns = "http://www. w3. org/1999/xhtml" > 
< head runat = "server"> 
<title></title> 
</head> 
<body> 
<form id = "forml" runat = "server"> 
<div> 
<asp:Button ID = "Button1”runat = "server" Font ~ Bold= "True" 
OnClick = "Buttonl_Click" Text = " 单 击 " />< br /> 
<asp:Label ID = "Labell" runat = "server" Height = "15px" 
Width= "225px"></asp: Label > gnbsp; 
</div> 
</form> 
</body> 
</html > 


@ 在 网 页 上 设计 如 下 事件 过 程 : 


protected void Button1_Click(object sender, EventArgs e) 
{ 

Labell.Text = "上 机 实验 题 1"; 
} 


上 机 实验 题 2 


设计 步骤 如 下 : 
@ 在 ch2 网 站 中 添加 一 个 Experment2 网 页 (采用 单 文 件 页 模型 ) 。 
@ 其 源 视 图 代码 ( 含 客户 端 脚 本 和 服务 器 脚本 ) 如 下 : 


A 
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< 外 @ Page Language= "C#" %> 
<!DOCTYPE html > 
< script type = "text/javascript"> 

function display() { 

document. getElementById("Label2").textContent = 
"你 的 输入 : " + forml. Textl1. value; 

} 
</script> 
< script runat = "server"> 

protected void Buttonl1_Click(object sender, EventArgs e) 


{ 
Labell.Text =“ 你 的 输入 : "+ TextBoxl. Text; 
' 
</script> 
<html xmlns = "http://www. w3.org/1999/xhtml"> 
<head runat = "server"> 
<meta http - equiv= "Content ~ Type" content = "text/html; charset = utf- 8"/> 
<title></title> 
<style type = "text/css"> 
,auto - stylel { font - family: 黑体 ; 
font ~ weight: bold; font ~ size: medium; 
color: 井 FF0000; width: 112px; 
} 
.auto— style2 { 
font - family: 楷体 ; font - weight: bold; 
font - size: medium; color: 间 0000FF; 
} 
</style> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
<span class = "auto - style2"> 输 入 : </span> 
<asp: TextBox ID = "TextBox1" runat = "server"></asp:TextBox> 
<br /><br /> 
<asp:Button ID = "Buttonl" runat = "server" CssClass = "auto— stylel" 
OnClick = "Buttonl_Click" Text = "服务 器 按钮 ”/> 
<br /><br /> 
<asp:Label ID= "Labell" runat = "server" style= "color: #FFOOFF; 
font - size: medium; font - weight: 700; font - family: 仿宋 "></asp:Label> 
<br /><br /> 
<span class = "auto- style2"> 输 入 : </span>< input id = "Text1" type = "text" /><br /> 
<br /> 
< input id = "Button2" class= "auto— stylel" type = "button" 
value = "客户 端 按钮 ”onclick= "display()" /><br /> 
<br /> 
<asp:Label ID= "Label2" runat = "server" style= "color: #FFOOFF; 
font - size: medium; font — weight: 700; font - family: 仿宋 "></asp:Label> 
</div> 
</form> 
</body > 
</html > 
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上 机 实验 题 3 


设计 步骤 如 下 : 
@ 在 ch3 网 站 中 添加 一 个 外 部 样式 表 文件 StyleSheet2. css, 其 代码 如 下 : 
.auto— stringstyle /* 输 入 文本 框 提示 文字 样式 */ 
{ ”font 一 family: 楷体 ; font - size: medium; 
color: 井 0000FF; font — weight: bold; 


text ~ align:right; height:22px; 
} 
.auto - captionstyle /* 标题 样式 * / 
{ font - size: 16pt; color: 井 ff0099; 
font - family: 幼 圆 ; font - weight: bold; 
text ~ align:center; height:40px; 
} 
.auto ~ buttonstyle /* 命令 按钮 样式 x / 
{ font — weight: bold; color: red; 
font - family: 黑体 ; font - size: medium; 


} 
,auto — dispText /* 显示 文本 框 样 式 */ 
{ width: 282px; color: #FFOOFF; 
font — size: medium; font— weight: 700; 
font - family: 仿宋 ; background 一 color: 井 99ccff; 
} 井 tablecenter /* 表格 居中 样式 * / 
{ margin- left: auto; margin 一 right: auto; 


vertical ~ align: middle; background— color: #99ccff; 
width:300px; 
} 


@ 在 ch3 网 站 中 添加 一 个 Experment3 网 页 (采用 单 文件 页 模型 ) 。 
@ 其 源 视图 代码 如 下 : 


<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
< script type = "text/javascript"> 
function settext() { 
document. getElementById("Text3").value = 
"学 号 :"” + document.getElementById("Text1").value + 
"姓名 ”+ document. getElementById("Text2"). value; 


} 
function setnull() { 
document. getElementById("Text1").value = ""; 
document. getElementById("Text2").value = ; 
} 
</script> 
<head> 
<meta http - equiv= "Content — Type" content = "text/html; charset =utf— 8"/> 
<title></title> 
< link href = " StyleSheet2.css" rel ="stylesheet" /> 
</head> 
<body> 
<div> 


<table id = "tablecenter" > 
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<tr> 
<td colspan = "2" class = "auto - captionstyle"> 我 的 信息 </td> 
</tr> 
<tr> 
<td class= "auto- stringstyle" style= "width:100px"> 学 号 </td> 
<td style= "width:200px">< input id= "Textl" type = "text" /></td> 
</tr> 
<tr> 
<tdclass="auto- stringstyle"> 姓 名 </td> 
<td>< input id= "Text2" type= "text" /></td> 
</tr> 
<tr> 
<td colspan= "2" style= "text 一 align:center"> 
< input id = "Button1l" type = "button" value= "确定 " 
onclick = "settext()" class = " auto - buttonstyle" /> 
Snbsp; gnbsp; 
< input id = "Resetl" type= "reset" value = " 重 置 " onclick= "setnul1()" 
class = "auto - buttonstyle" /> 


</td> 
</tr> 
<tr> 
<td colspan = "2" > 
< input id = "Text3" type = "text" class= " auto- dispText” 
aria- readonly = "True" /></td> 
</tr> 
</table> 
</div> 
</body> 
</html > 


上 机 实验 题 4 


设计 步骤 如 下 : 
@ 打开 ch4 网 站 的 Classl. css 类 文件 ,在 其 中 添加 如 下 类 ; 


public class Class4 
{ public string link(params string[ ] strarr) 
{ inti; string mystr = ""; 
for (i = 0; i< strarr.Length;i++) 
mystr += strarr[i] + " "; 
return mystr; 
} 
public void sort(params string[ ] strarr) 
{ int i, j; string tmp; 
bool exchange; // 交 换 标志 
for (i = 0; i< strarr.Length - 1; i++) 
' exchange = false; 
for (j = strarr.Length - 2; j>= i; j--) 
if (String. Compare(strarr[j + 1],strarr[j])<0) 
{ tmp = strarr[j + 1]; //tmp 暂 存 数组 元 素 ， 用 于 元 素 交 换 
strarr[j + 1] = strarr[j]; 
strarr[j] = tmp; 
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exchange = true; // 发 生 了 交换 , 故 将 交换 标志 置 为 真 
} 
if (exchange == false) // 本 趟 未 发 生 交 换 ， 提 前 终止 算法 
return; 


} 


@ 在 ch4 网 站 中 添加 一 个 Experment4 网 页 (采用 代码 隐藏 页 模型 ) ,其 源 视图 代码 如 下 : 


<% @ Page Language = "C 井 "RutoEventWireup = "true" CodeF ile = "Experment4. aspx. cs" 
Inherits = "Experment4"” %> 
<html xmlns = "http://www.w3.org/1999/xhtml" > 
<head runat = "server"> 
<title ></title> 
< style type = "text/css"> 
.auto- stylel { font - family: 仿宋 ; 
font - weight: bold; font— size: medium; 
color: #3FFOOFF; width:400px; 
} 
</style> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
< strong style = "color: 井 0000FF; font - size: medium; font - family: 楷体 "> 
排序 前 : </strong> 
<asp:Label ID= "Labell" runat = "server" class = "auto- stylel"></asp:Label > 
<br /><br /> 
<asp:Button ID= "Button1l" runat = "server" Font ~ Bold= "True" 
OnClick = "Buttonl_Click" Text = "排序 " 
style = "color: 井 FF0000; font - size: medium; font - family: 黑体 " /> 
<br /> <br /> 
< strong style = "color: 井 0000FF; font - size: medium; font - family: 楷体 "> 
排序 后 : </strong> 
<asp:Label ID= "Label2" runat = "server" 
CssClass = "auto - stylel" ></asp:Label ></div> 
</form> 
</body> 
</html > 


@ 本 网 页 的 程序 代码 如 下 : 


using System/ 
public partial class Experment4 : System. Web. UI. Page 
{ Class4 obj = new Class4(); 
string[ ] strarr = new string[ ]{ "while", "if", "for", "break", "switch", 
"if ~ else", "do— while"，"continue"”}; 
protected void Page_Load(object sender, EventArgs e) 
{ 
Labell.Text = obj.link(strarr); 
} 
protected void Buttonl _Click(object sender, EventArgs e) 
{ obj. sort( strarr); 
Label2. Text = obj.link(strarr); 
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上 机 实验 题 5 


设计 步骤 如 下 : 
@ 在 ch5 网 站 中 添加 一 个 Experment5 网 页 (采用 代码 隐藏 页 模型 ) 。 
@ 其 源 视 图 代码 如 下 : 


< 外 @ Page Language = "C#" RutoEventWireup = "true" CodeF ile = "Experment5. aspx. cs" 
Inherits = "Experment5" $%> 
<htm]l xmlns = "http://www.w3.org/1999/xhtml" > 
<head runat = "server"> 
<title ></title> 
< style type = "text/css"> 
<! -一 省 略 若干 样式 定义 一 > 
</style> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
<table> 
<tr> 
<td class = "auto - style7">< strong > 学 号 </strong></td> 
<td style= "font - size: 12pt; width: 100px; height: 26px"> 
<asp:TextBox ID = "TextBox1" runat = "server" 
Font — Size = "10pt"></asp:TextBox> 
</td> 
</tr> 
<tr style= "font— size: 12pt; color: 井 0000ff"> 
<td class= "auto- style6">< strong > 姓名 </strong></td> 
<td style= "color: 井 000000" class = "auto- stylel"> 
<asp:TextBox ID = "TextBox2" runat = "server" Font ~ Size= "10pt"> 
</asp:TextBox > 
</td> 
</tr> 
<tr style= "font ~ size: 12pt; color: #000000"> 
<td class = "auto - style4">< strong > 性别 </strong></td> 
<td style= "width: 100px"> 
<asp:TextBox ID= "TextBox3" runat = "server" 
Font ~ Size = "10pt"></asp:TextBox> 
</td> 
</tr> 
<tr> 
<td class = "auto— style4">< strong> 班 号 </strong></td> 
<td style = "width: 100px"> 
<asp:TextBox ID = "TextBox4" runat = "server" 
Font ~ Size = "10pt"></asp:TextBox> 
</td> 
</tr> 
<tr> 
<td colspan = "2" style= "text 一 align:center"> 
<asp:Button ID = "Button1”runat = "server" OnClick= "Buttonl Click" 
Text = "确定 " CssClass = "auto style2" /> 
Snbsp; &nbsp; 
< input id = "Button2" runat = "server" font— size= "10pt" text = " 重 置 " 
type= "reset" value = " 重 置 " class = "auto - style2" /> 
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</td> 
</tr> 
</table> 
</div> 
</form> 
</body> 
</html > 


@ Experment5 网 页 的 事件 处 理 过 程 如 下 : 


protected void Buttonl Click(object sender, EventArgs e) 
{ string mystr; 
ystr = "Experment5—1.aspx?sno=" + TextBox1.Text.Trim() + 
"gsname = ”+ TextBox2.Text.Trim() + "&ssex=" + TextBox3.Text.Trim() + 
"gsclass=" + TextBox4.Text. Trim(); 
Server. Transfer (mystr); 


} 
@ 在 ch5 网 站 中 添加 一 个 Experment5-1 网 页 (采用 代码 隐藏 页 模型 ) ,不 包含 任何 控件 ， 
其 事件 处 理 过 程 如 下 : 


protected void Page_Load( object sender, EventArgs e) 

{ string sno = Request. QueryString["sno"]; 
string sname = Request. QueryString["sname"]; 
string ssex = Request.QueryString["ssex"]; 
string sclass = Request.QueryString["sclass"]; 
Response. Write(" 学 生 信息 如 下 :<br>"); 
Response. Write(" 学 号 :" + sno + "<br>"); 
Response. Write(" 姓 名 :" + sname + "<br>"); 
Response. Write(" 性 别 :" + ssex + "<br>"); 
Response. Write(" 班 号 :" + sclass); 


， 


上 机 实验 题 6 


设计 步 又 如 下 ， 
J@ 在 ch6 网 站 中 添加 一 个 Experment6 网 页 (采用 代码 隐藏 页 模型 ) 。 
@ 其 源 视图 代码 如 下 : 


<% @ Page Language = "C#" AutoEventWireup= "true" CodeFile = "Experment6. aspx. cs" 
Inherits = "Experment6" $%> 
<html xmlns = "http://www.w3.org/1999/xhtml" > 
< head runat = "server"> 
<title></title> 
<style type= "text/css"> 
<! -一 省 略 若干 样式 定义 一 > 
</style> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
<table> 
<tr> 
<td class= "auto— style3">< strong > 学 号 </strong></td> 
<td style= "width: 100px; height: 26px;"> 
<asp:TextBox ID = "TextBoxl”runat = "server" 
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Font— Size = "10pt"></asp:TextBox> 
</td> 
</tr> 
<tr> 
<td style= "width: 78px; text ~ align: right" class = "auto— style2"> 
< strong>< span class = "auto - stylel"> 姓 名 </span></strong></td> 
<td style = "width: 100px"> 
<asp:TextBox ID = "TextBox2" runat = "server" 
Font— Size = "10pt"></asp:TextBox> 
</td> 
</tr> 
<tr> 
<td style = "width: 78px; text ~ align: right" class = "auto— style2"> 
< strong >< span class = "auto - stylel"> 性 别 </span></strong></td> 
<td style= "width: 100px"> 
<asp:RadioButton ID = "RadioButton1”runat = "server" Font ~ Bold= "True" 
Font ~ Size = "10pt" Text = " 男 " Checked = "True" GroupName = "xb" /> 
<asp:RadioButton ID= "RadioButton2" runat = "server" 
Font ~ Bold = "True" Font ~ Size = "10pt" Text = " 女 " GroupName = "xb" /> 
</td> 
</tr> 
<tr> 
<td class= "auto- style4">< strong> 班 号 </strong></td> 
<td style = "width: 100px"> 
<asp:DropDownList ID = "DropDownList1”runat = "server" Font ~ Bold= "True" 
Font ~ Size="10pt" Width = "88px"> 
<asp:ListItem > 1501 </asp:ListItem> 
<asp:ListItem > 1502 </asp:ListItem> 
<asp:ListItem > 1503 </asp:ListItem> 
</asp:DropDownList ></td> 
</tr> 
<tr> 
<td colspan= "2" style= "text ~ align:center"> 
<asp:Button ID = "Buttonl" runat = "server" Text = "确定 " 
OnClick = "Buttonl_Click" CssClass ="auto— style5" /> 
gnbsp;< input type = "reset" ID= "Button2" runat = "server" Font ~ Size= "10pt" 
Text = " 重 置 " class = "auto- style5" /><br /> 
</td> 
</tr> 
<tr> 
<td colspan = "2"> 
<asp:Label ID = "Labell" runat = "server" 
style = "color: #FF0099; font - weight: bold; font - size: medium; 
font - family: 仿宋 "></asp:Label > 


</td> 
</tr> 
</table> 
</div> 
</form> 
</body> 
</html > 


@ 本 网 页 的 事件 处 理 过 程 如 下 : 


protected void Buttonl_Click(object sender, EventArgs e) 
{ string xb; 
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if (RadioButton1. Checked == true) 
xb = " 男 "; 
else 
xb = " 女 "7 
Labell. Text = "输入 信息 : <br> gnbsp;&nbsp; 学 号 :" + TextBoxl. Text + 
"gnbsp;&nbsp; 姓 名 :" + TextBox2.Text + "<br>" + 
"gnbsp;&nbsp; 性 别 :" + xb + 
"gnbsp;&nbsp; 班 号 :" + DropDownList1l.SelectedValue; 


上 机 实验 题 7 


设计 步骤 如 下 : 
@ 在 ch7 网 站 中 添加 一 个 Experment7 网 页 (采用 代码 隐藏 页 模型 ) 。 
@ 其 源 视图 代码 如 下 : 


<% @ Page Language = "C 井 ”RutoEventWireup = "true" CodeFile = "Experment7. aspx. cs" 
Inherits = "Experment7" $%> 
<html xmlns = "http://waw.w3.org/1999/xhtml" > 
< head runat = "server"> 
<title></title> 
<style type= "text/css"> 
<! -- 省 略 若干 样式 定义 一 > 


</style> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
<table style= "width:300px"> 
<tr> 
<td class= "auto- stylel"> 学 号 </td> 


<td class= "auto- style5"> 
<asp:TextBox ID = "TextBoxl”runat = "server" 
style = "width:100px"></asp:TextBox > 
</td> 
<td style= "width:45% "> 
<asp:RequiredFieldValidator ID= "RequiredFieldValidator1" 
runat = "server" ControlToValidate = "TextBox1" 
ErrorMessage = "学 号 不 能 为 空 " CssClass = "auto - style3"> 
</asp:RequiredFieldValidator ></td> 
</tr> 
<tr> 
<td class = "auto- stylel"> 姓 名 </td> 
<td class = "auto— style6" > 
<asp:TextBox ID = "TextBox2" runat = "server" 
style = "width:100px"></asp:TextBox> 
</td> 
<td> 
<asp:RequiredFieldValidator ID= "RequiredFieldValidator2" 
runat = "server" ControlToValidate = "TextBox2" 
ErrorMessage = "姓名 不 能 为 空 " CssClass = "auto style3"> 
</asp:RequiredFieldValidator> 
</td> 
</tr> 


<tr> 
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<td class = "auto- stylel" > 性 别 </td> 
<td class = "auto— style6"> 
<asp:RadioButton ID = "RadioButton1”runat = "server" Text =" 男 " 
Checked = "True"” GroupName = "xb" CssClass= "auto - style4" /> 
<asp:RadioButton ID = "RadioButton2" runat = "server" Text = " 女 " 
GroupName = "xb" CssClass= "auto— style4" /> 
</td> 
</tr> 
<tr> 
<tdclass= "auto- stylel" > 班 号 </td> 
<td class= "auto- style6" > 
<asp:TextBox ID = "TextBox3" runat = "server" 
style = "width:100px"></asp:TextBox> 
</td> 
<td> 
<asp:CustomValidator ID = "CustomValidatorl”runat = "server" 
ErrorMessage = " 班 号 不 正确 ”CssClass = "auto- style3" 
ControlToValidate = "TextBox3" 
OnServerValidate = "CustomValidator1_ServerValidate"> 
</asp:CustomValidator > 
</td> 
</tr> 
<tr> 
<td colspan= "2" style= "text 一 align:center"> 
<asp:Button ID = "Button1”runat = "server" Text = "确定 " 
OnClick = "Buttonl_Click" CssClass = "auto— style2" /> 
Snbsp; &nbsp; 
< input type = "reset" ID= "Button2" runat = "server" 
Text = " 重 置 " class = "auto - style2" /><br /> 


nm 


</td> 
</tr> 
<tr> 
<td colspan = "3"> 
<asp:Label ID = "Labell" runat = "server" style = "color: #3FFOOFF; 
font- size: medium; font - weight: 700; font - family: 仿宋 "> 
</asp:Label> 
</td> 
</tr> 
</table> 
</div> 
</form> 
</body> 
</html > 


@ 本 网 页 的 事件 处 理 过 程 如 下 : 


protected void Button1_Click(object sender, EventArgs e) 
{ if (Page. IsValid) 
{ string xb; 
if (RadioButton1. Checked == true) 
xb = " 男 "; 
else 
xb =" 女 "; 
Labell.Text = "输入 信息 : <br>"+ 
"gnbsp;&nbsp; 学 号 :" + TextBoxl. Text + 
"gnbsp;&nbsp; 姓 名 :" + TextBox2.Text + "<br>" + 
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"gnbsp;&nbsp; 性 别 :" + xb + 
"gnbsp;&nbsp; 班 号 :" + TextBox3. Text; 


} 
Protected void CustomVal idator1_ServerVal idate(object source, 
System. Web. UI. WebControls. ServerValidateEventArgs args) 
{ string bh = args. Value; 
if (bh.Length> 4 && bh[0] == '1'&& bh[1] 
args. IsValid = true; 
else 
args. IsValid = false; 


'5') 


上 机 实验 题 8 
设计 步骤 如 下 : 


@ 在 ch8 网 站 中 添加 一 个 名 称 为 WebUserControl2. ascx 的 用 户 控件 。 


@ WebUserControl2. ascx 的 源 视图 代码 如 下 : 


<% @ Control Language = "C#" AutoEventWireup= "true" CodeFile = "WebUserControl2.ascx.cs" 


Inherits = "WebUserControl2" %> 
<table> 
<tr> 


<td colspan = "2" style = "height: 21px; text ~ align: center"> 


< span style= "font - size: 16pt; color: #ff0099; 


font - family: 华文 隶书 ">< strong > 用 户 登录 </strong></span> 


</td> 
</tr> 
<tr> 


<td style = "width: 50px; height: 26px; text ~ align: center"> 
< span style = "font — size: 10pt; color: 井 0000ff">< strong> 


用 户 名 </strong></span > 
</td> 
<td style = "width: 77px; height: 26px"> 


<asp:TextBox ID = "TextBoxl"”runat = "server" Font ~ Bold = "True" 
Font - Size = "10pt" Height = "16px" Width = "128px"></asp:TextBox> 


</td> 
</tr > 
<tr > 


<td style= "width: 50px; height: 24px; text 一 align: center"> 
< strong >< span style = "font - size: 10pt; color: 井 0000ff"> 


密 码 </span ></strong> 
</td> 
<td style= "width: 77px; height: 24px"> 


<asp:TextBox ID = "TextBox2" runat = "server" Font ~ Bold = "True" 


Font ~ Size = "10pt" Height = "16px" 


TextMode = "Password" Width= "128px"></asp:TextBox> 


</td> 
</tr> 
</table> 


@ WebUserControl2. ascx 的 事件 处 理 过 程 如 下 : 


public string uid 
{ 


507 


508 


P.NET 4.5 动态 网 站 设计 教程 一 一 基于 C# 5. 0 十 SQL Server 2012 


get { return TextBoxl1. Text; } 


和 
public string upass 
{ 
get { return TextBox2. Text; } 
: 


@ 在 ch8 网 站 中 添加 一 个 Experment8 网 页 (采用 代码 隐藏 页 模型 ) 。 
@ Experment8 网 页 的 源 视 图 代码 如 下 : 


<% @ Page Language = "C#" RutoEventWireup = "true" CodeF ile = "Experment8. aspx. cs" 
Inherits = "Experment8" $%> 
< 外 @ Register src = "WebUserControl2.ascx" tagname = "WebUserControl2" tagprefix= "ucl" $%> 
<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head runat = "server"> 
<meta http - equiv= "Content ~ Type" content = "text/html; charset = utf -8"/> 
<title></title> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
<ucl:WebUserControl2 ID = "WebUserControl21" runat = "server" /> 
</div> 
<br /> 
<asp:Button ID = "Buttonl" runat = "server" OnClick = "Buttonl_Click" 
style = "color: #3FF0000; font - size: medium; font — weight: 700; 
font - family: 黑体 ”Text = "确定 " /> 
<br /><br /> 
<asp:Label ID= "Labell" runat = "server" style= "color:#FFOOFF; font— size:medium; 
font - weight: 700; font - family: 仿宋 "></asp:Label> 
</form> 
</body > 
</html > 


@ Experment8 网 页 的 事件 处 理 过 程 如 下 : 


protected void Button1_Click(object sender, EventArgs e) 

{ ”Labell.Text = "输入 信息 如 下 :" + "<br>" + 
"gnbsp &nbsp &nbsp 用 户 名 :" + WebUserControl21.uid + "<br>" + 
" gnbsp &nbsp &nbsp 密 &nbsp 码 :”+ WebUserControl21.upass; 


上 机 实验 题 9 


设计 步骤 如 下 : 
@ 在 ch9 网 站 中 添加 一 个 MasterPage2. master 母 版 页 (采用 代码 隐藏 页 模型 ) 。 
@ 其 源 视 图 代码 如 下 (不 含 脚本 代码 ) : 


<$% @ Master Language = "C#" AutogventWireup= "true" CodeFile = "MasterPage2. master.cs" 
Inherits= "MasterPage2" %> 
<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head runat = "server"> 
<meta http - equiv= "Content ~ Type" content = "text/htm1; charset = utf— 8"/> 
<title></title> 
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<asp: ContentPlaceHolder id="head" runat = " server"></asp: ContentPlaceHolder > 
< style type = "text/css"> 
<! -一 省 略 若干 样式 定义 一 > 
</style> 
</head> 
<body> 
<form id= "forml" runat = " server"> 
<div> 
< table border = "0" cellpadding = "0" cellspacing = "0" align= "center"> 
<tr> 
<td colspan = "3" style= "text — align:center;height:30px; 
background- color: ThreeDFace"> 学 生 信息 管理 系统 
</td> 
</tr> 
<tr> 
<td style = "width:2 % ;background - color: ThreeDFace""></td> 
<td style = "width:96 % "> 
<asp:ContentPlaceHolder id = "ContentPlaceHolderl" runat = "server"> 
</asp:ContentPlaceHolder > 
</td> 
<td style = "width:2 % ;background - color: ThreeDFace""></td> 
</tr> 
<tr> 
<td colspan = "3" style = "text ~ align:center;height:30px; 
background— color: ThreeDFace; font ~ size: small; font - weight: 700; 
font - family: 黑体 ;"> v2.0, 版权 所 有 
</td> 
</tr> 
</table> 
</div> 
</form> 
</body> 
</html > 


@ 在 ch9 网 站 中 添加 一 个 Experment9 网 页 (采用 代码 隐藏 页 模型 ) 。 
@ 其 源 视图 代码 如 下 : 


<% @ Page Title= "" Language = "C#" MasterPageFile= "~ /MasterPage2.master" 
AutoEventWireup= "true" StyleSheetTheme = "Exper" 
CodeFile = "Experment9.aspx.cs" Inherits= "Experment9" %> 
<asp:Content ID = "Content1" ContentPlaceHolderID = "head" Runat = " Server"> 
<style type= "text/css"> 
<! -省略 若干 样式 定义 -一 > 
</style> 
</asp:Content > 
<asp:Content ID = "Content2" ContentPlaceHolderID = "ContentPlaceHolder1l" 
Runat = "Server"> 
<table class = "auto - style3"> 
<tr> 
<td class = "auto- style5"> 学 号 </td> 
<td class ="auto- style6"> 
<asp:TextBox ID = "TextBoxl"” runat = "server"></asp:TextBox> 
</td> 
</tr > 
<tr> 
<td class = "auto- style4"> 姓 名 </td> 
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<td> 
<asp:TextBox ID = "TextBox2" runat = "server"></asp:TextBox> 
</td> 
</tr> 
<tr> 
<td colspan = "2" style= "text ~ align:center"> 
<asp:Button ID= "Buttonl" runat = "server" 
Text = "确定 " OnClick = "Buttonl_Click" /> 
</td> 
</tr> 
<tr> 
<td colspan = "2"> 
<asp:Label ID = "Labell" runat = " server"></asp:Label> 
</td> 
</tr> 
</table> 
</asp:Content > 


@ 本 网 页 的 事件 处 理 过 程 如 下 : 


protected void Button1_Click(object sender, EventArgs e) 
{ ”Labell.Text = "输入 信息 : <br>" + 
"gnbsp;&nbsp; 学 号 : ”+ TextBoxl. Text + "&nbsp;&nbsp; 姓 名 : " + TextBox2. Text; 


上 机 实验 题 10 


设计 步骤 如 下 : 

@ 在 ch10 网 站 中 添加 一 个 Experment10 网 页 (采用 代码 隐藏 页 模型 ), 其 中 放置 一 个 
TreeView 控件 和 一 个 iframe 框架 ,采用 手工 方式 添加 TreeView 控件 的 结 点 。 

@ Experment10 网 页 的 源 视图 代码 如 下 : 


<% @ Page Language= "C 井 ”RutoEventWireup = "true" CodeFile = "Experment10.aspx. cs" 
Inherits = "Experment10" %> 
<html xmlns = "http://www.w3.org/1999/xhtml" > 
<head runat = "server"> 
<title></title> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
< table style= "width:600px; height: 212px;"> 
<tr> 
<td> 
<asp:TreeView ID = "TreeViewl" runat = "server" Font ~ Bold= "True" 
ImageSet = "News" NodeIndent = "10" 
style = "color: 井 0000FF; font- size: medium; font - family: 仿宋 ;"> 
< HoverNodeStyle Font - Underline= "True" /> 
<Nodes> 
<asp:TreeNode Text = "学 生 管理 "Value = "学 生 管理 " 
NavigateUrl = "dispinfo.aspx?info = 选择 : 学 生 管理 " Target = "Iframel"> 
<asp:TreeNode Text = "添加 学 生 信 息 ”Value = "添加 学 生 信 息 " 
NavigateUrl = "dispinfo.aspx?info= 选择 : 添加 学 生 信 息 
Target = "Iframel"> 
</asp:TreeNode > 
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<asp:TreeNode Text = "编辑 学 生 信息 ”Value = "编辑 学 生 信息 
NavigateUrl = "dispinfo.aspx?info = 选择 : 编辑 学 生 信息 " 
Target = "Iframel"> 
</asp:TreeNode > 
<asp:TreeNode Text = "学 生成 绩 输入 " Value = "学 生成 绩 输入 " 
NavigateUrl = "dispinfo.aspx?info = 选择 : 学 生成 绩 输入 " 
Target = "Iframel"> 
</asp:TreeNode > 
<asp:TreeNode Text = "查询 学 生成 绩 ” Value = "查询 学 生成 绩 " 
NavigateUrl = "dispinfo.aspx?info = 选择 : 查询 学 生成 绩 " 
Target = "Iframel"> 
</asp:TreeNode > 
</asp:TreeNode > 
<asp:TreeNode Text = "教师 管理 " Value = "教师 管理 " 
NavigateUrl = "dispinfo.aspx?info = 教师 管理 ”Target = "Iframel"> 


Target = "Iframel"> 
</asp:TreeNode > 
<asp:TreeNode Text = "编辑 教师 信息 ”value = "编辑 教师 信 
NavigateUrl = "dispinfo.aspx?info= 选择: 编辑 教师 信 
Target = "Iframel"> 
</asp:TreeNode > 
<asp:TreeNode Text = "安排 教师 授课 ”Value = "安排 教师 授课 " 
NavigateUrl = "dispinfo.aspx?info = 选择: 安排 教师 授课 " 
Target = "Iframel"> 
</asp:TreeNode > 
</asp:TreeNode > 
</Nodes> 
< NodeStyle Font - Names = "Arial" Font ~ Size = "10pt" ForeColor = "Black" 
HorizontalPadding = "5px" NodeSpacing = "0px" VerticalPadding = "0px" /> 
< ParentNodeStyle Font - Bold = "False" /> 
< SelectedNodeStyle Font - Underline = "True" HorizontalPadding = "0px" 
VerticalPadding = "0px" /> 
</asp:TreeView> 
</td> 
<td style= "width: 99 % ; height: 100% ;"> 
<div style= "text ~ align:center"> 
< iframe name = "Iframel” 
style=" height:100 % ; width:99 % ;text - align:center" 
id = "Iframel”src = "dispinfo. aspx?info= 欢迎 使 用 本 系统 "> 
</ iframe > 
</div> 
</td> 
</tr> 
</table> 
</div> 
</form> 
</body> 
</html > 


@ 在 ch10 网 站 中 添加 一 个 dispinfo 网 页 ,其 中 有 一 个 标签 Labell ,包含 的 事件 过 程 
如 下 : 


protected void Page_Load(object sender, EventArgs e) 
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Labell. Text = Request. QueryString["info"]; 


上 机 实验 题 11 


设计 步骤 如 下 : 
@ 在 chll 网 站 中 添加 一 个 Experment11 网 页 (采用 代码 隐藏 页 模型 ) 。 
@ 其 源 视图 代码 如 下 : 


< 外 @ Page Language = "C#" RutoEventWireup = "true" CodeFile = "Experment11. aspx. cs" 
Inherits = "Experment11" %> 
<!DOCTYPE html > 
<“html xmlns = "http://www.w3.org/1999/xhtml"> 
<head runat = "server"> 
<meta http - equiv= "Content — Type" content = "text/html; charset = utf— 8"/> 
<title></title> 
<style type= "text/css"> 
.auto— stylel { 
font - family: 楷体 ; font - weight: bold; 
font - size: medium; color: 井 0000FF; 
} 
</style> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<asp:ScriptManager ID = "ScriptManager1" runat = "server"></asp:ScriptManager > 
<asp:Timer ID= "Timerl”runat = "server" Interval = "1000" OnTick= "Timer1l_Tick"> 
</asp: Timer > 
<div> 
<asp:UpdatePanel ID = "UpdatePanell" runat = "server"> 
< ContentTemplate > 
< span class = "auto - stylel1"> 倒 计时 秒 数 : </span > 
<asp:TextBox ID = "TextBoxl" runat = "server" Width = "36px"></asp:TextBox> 
<br /><br /> 
<asp:Button ID = "Button1" runat = "server" OnClick = "Buttonl_Click" 
style = "color: 井 FF0000; font— size: medium; font ~ weight: 700; 
font- family: 黑体 " Text = "开始 "” /> 
<br /><br /> 
< span class = "auto - stylel"> 剩 余 秒 数 : </span> 
<asp:TextBox ID = "TextBox2" runat = "server" ReadOnly = "True" 
Width = "50px"></asp:TextBox> 
</ContentTemplate> 
</asp:UpdatePanel > 
</div> 
</form> 
</body > 
</html > 


@ 本 网 页 的 程序 代码 如 下 : 


using System; 
using System. Web. UI; 
public partial class Experment11 : System. Web. UI.Page 
{ static int i= 0; 
protected void Page Load(object sender, EventArgs e) 
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{ if (!Page. IsPostBack) 
{ Timerl.Interval = 1000; /人 1 秒 
Timerl. Enabled = false; 


} 
protected void Buttonl1_Click(object sender, EventArgs e) 


{ 证 (TextBoxl.Text != "") 
和 i = int.Parse(TextBoxl. Text); 
TextBox2. Text = i.ToString(); 
Timerl. Enabled = true; 


} 
protected void Timerl_Tick(object sender, EventArgs e) 
{ if(i!= 0) 

{ == 


TextBox2. Text i.ToString(); 


} 


else 
{ ”TextBox2. Text =“" 时 间 到 "; 
Timerl. Enabled = false; 


上 机 实验 题 12 


设计 步骤 如 下 : 
@ 在 chl2 网 站 中 添加 一 个 Experment12 网 页 (采用 代码 隐藏 页 模型 )。 


@ 其 源 视图 代码 如 下 : 


< 外 @ Page Language = "C 井 ”RutoEventWireup = "true" CodeFile = "Experment12. aspx. cs 
Inherits = "Experment12" %> 
<html xmlns = "http://www.w3.org/1999/xhtml" > 
<head runat = "server"> 
<title></title> 
<style type= "text/css"> 
.auto— stylel { 
font - family: 楷体 ; font - size: 10pt; 
font ~ weight: bold; color:blue; 


} 
</style> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
<table id="tablel" style = "width: 488px; height: 200px;"> 
<tr> 
<td style = "width: 431px; height: 10% ; text— align: center;"> 
<strong>< span style = "color: 井 ff0066; font - family: 华文 仿宋 ; 
font- size: 14pt;i"> 学 生成 绩 表 </ span></strong> 
</td> 
</tr> 
<tr> 
<td style = "width: 431px; height: 49% ;"> 
<asp:GridView ID = "GridView1”runat = "server" AllowPaging = "True" 
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AutoGenerateColumns = "False" 
CellPadding= "4" Font ~ Bold= "True" 
Font — Size = "10pt" ForeColor = " #333333" 
GridLines = "None" PageSize = "4" 
Width = "441px" Height = "137%" 
OnPageIndexChanging = "GridViewl PageIndexChanging" 
OnDataBound = "GridViewl DataBound"> 
<EditRowStyle BackColor = "#7C6F57" /> 
<Columns > 
<asp:BoundField DataField= "学 号 ”HeaderText = "学 号 "> 
< ItemStyle HorizontalAlign = "Center" /> 
</asp: BoundField> 
<asp:BoundField DataField= "姓名 ”HeaderText = "姓名 "> 
< ItemStyle HorizontalAlign = "Center" /> 
</asp:BoundField> 
<asp:BoundField DataField= "课程 名 ”HeaderText = "课程 名 "> 
< ItemStyle HorizontalAlign = "Center" /> 
</asp: BoundField> 
<asp:BoundField DataField= "分数 ”HeaderText = "分 数 "> 
< ItemStyle HorizontalAlign = "Center" /> 
</asp:BoundField> 
<asp:BoundField DataField= " 班 号 ”HeaderText = " 班 号 "> 
< ItemStyle HorizontalAlign = "Center" /> 
</asp:BoundField> 
</Columns > 
<RowStyle BackColor = " #E3EAEB" /> 
< SelectedRowStyle BackColor =" 间 C5BBAF" ForeColor = " #333333" 
Font ~ Bold= "True" /> 
<PagerStyle BackColor = "#666666" ForeColor = "White" 
HorizontalAlign= "Center" Font ~ Bold= "True" Font - Size= "12px" 
Font - Names = " 幼 圆 " /> 
<HeaderStyle BackColor = "#1C5E55" Font ~ Bold = "Tru 
ForeColor = "Red" Font - Names = "黑体 " Font - Size= "Medium" /> 
<AlternatingRowStyle BackColor = "White" /> 
< SortedAscendingCellStyle BackColor = " #F8FAFA" /> 
< SortedAscendingHeaderStyle BackColor = " 间 #246B61" /> 
< SortedDescendingCellStyle BackColor = " #D4DFE1" /> 
< SortedDescendingHeaderStyle BackColor = "#15524A" /> 
</asp:GridView > 
</td> 
</tr> 
<tr> 
<td style = "text ~ align:center"> 
<span class= "auto- stylel"> 当 前 页 :</span> 
<asp:Label ID = "Labell" runat = "server"></asp:Label > 
Snbsp; 
<span class= "auto- stylel"> 总 页 数 :</span> 
<asp:Label ID = "Label2" runat = "server"></asp:Label > 
Snbsp; 
<span class= "auto- stylel"> 转 向 </span > 
<asp:DropDownList ID = "DropDownList1”runat = " server"” 
Width= "60px"> 
</asp:DropDownList > 
<span class= "auto- stylel"> 页 </span> 
<asp:Button ID = "Button1”runat = "server" 
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OnClick = "Buttonl Click" Text ="..." Width= "34px" 
style= "color: 井 FE0000; font- size: small; font ~ weight: 700; 
font - family: 黑体 " /> 
</span> 
</td> 
</tr> 
</table> 
</div> 
</form> 
</body> 
</html > 


@ 本 网 页 的 程序 代码 如 下 


using System; 

using System. Data; 

using System. Configuration; 

using System. Web. UI; 

using System. Web. UI. WebControls; 

using System. Data. SqlClient; 

public partial class Experment12 : System. Web.UI.Page 

{ protected void Page Load(object sender, EventArgs e) 

{ if (!Page.IsPostBack) 
{ GridViewl.PagerSettings. Mode = PagerButtons.NextPreviousFirstLast; 
GridViewl.PagerSettings. FirstPageText = "首页 "; 
GridViewl. PagerSettings. NextPageText = "下 一 页 "; 
GridViewl. PagerSettings. PreviousPageText = "上 一 页 "; 
GridViewl.PagerSettings. LastPageText = " 尾 页 "; 
bind(); 
intn = GridViewl.PageCount; 
for (int i = 1; i<= n; i++) 
DropDownList1. Items. Add(i. ToSstring( )); 


} 
public void bind( ) // 数 据 绑 定 
{ stringmystr = 
ConfigurationManager. ConnectionStrings[ "myconnstring"].ToString( ); 
string mysql = "SELECT student. 学 号 , student. 姓名 ," + 
"score. 课程 名 , score. 分 数 , student. 班 号 "+ 
"FROM student, score " + 
"WHERE student. 学 号 = score. 学 号 "+ 
"ORDER BY student. 学 号 "; 
SqlConnection myconn = new SqlConnection(); 
myconn. ConnectionString = mystr; 
myconn. Open(); 
DataSet myds = new DataSet(); 
SqlDataAdapter myda = new SqlDataAdapter(mysql, myconn); 
myda. Fill(myds, "student"); 
GridView1.DataSource = myds.Tables[0]; 
GridView1.DataBind( ); 
myconn. Close( ); 
} 
Protected void GridViewl_PageIndexChanging( object sender, GridViewPageEventArgs e) 
{ // 分 页 
GridView1.PageIndex = e.NewPageIndex; 
bind(); 
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} 

protected void GridViewl DataBound(object sender, EventArgs e) 

{ int n= GridViewl.PageIndex + 1; 
Labell.Text = n.ToString(); 
Label2.Text = GridViewl.PageCount.ToString(); 

} 

protected void Buttonl Click(object sender, EventArgs e) 

{ GridView1.PageIndex = int.Parse(DropDownListl.SelectedValue)—1; 
bind(); 


上 机 实验 题 13 


设计 步骤 如 下 : 
中 在 chl3-1 网 站 中 添加 一 个 Experment13 网 页 (采用 代码 隐藏 页 模型 ) 。 
@ 其 源 视图 代码 如 下 : 


<% @ Page Language = "C#" AutoEventWireup = "true" CodeFile = "Experment13. aspx. cs" 
Inherits = "Experment13" %> 
<!DOCTYPE html > 
<html xmlns = "http://www. w3.org/1999/xhtml"> 
<head runat = "server"> 
<meta http - equiv= "Content — Type" content = "text/htm1; charset = utf — 8"/> 
<title ></title> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
<asp:GridView ID= "GridView1”runat = "server" CellPadding= 
ForeColor = "#333333" GridLines = "None" style= "font - size: medium; 
font - family: 仿宋 "> 
<“RlternatingRowStyle BackColor = "White" /> 
< EditRowStyle BackColor = " 间 7C6F57" /> 
< FooterStyle BackColor = "#1C5E55" Font ~ Bold = "True" ForeColor = "White" /> 
< HeaderStyle BackColor = "#1C5E55" Font ~ Bold = "True" ForeColor = "White" /> 
< PagerStyle BackColor = " 间 666666" ForeColor = "White" 
HorizontalAlign = "Center" /> 
< RowStyle BackColor = " # E3EAEB" /> 
< SelectedRowStyle BackColor = "#C5BBAF" Font - Bold = "True" 
ForeColor = " #333333" /> 
< SortedAscendingCellStyle BackColor = " # F8FAFA" /> 
< SortedAscendingHeaderStyle BackColor = " 间 246B61" /> 
< SortedDescendingCellStyle BackColor = "#D4ADFE1" /> 
< SortedDescendingHeaderStyle BackColor = " 间 #15524A" /> 
</asp:GridView> 
</div> 
</form> 
</body> 
</html > 


@ 本 网 页 的 程序 事件 处 理 过 程 如 下 : 


protected void Page_Load(object sender, EventArgs e) 
{ StudEntities dc = new StudEntities(); 


} 
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Var myquery = from st in dc. student 

join sc in dc. score on st. 学 号 equals sc. 学 号 

orderby st. 学 号 , sc. 分 数 descending 

select new { st. 学 号 ，st. 姓名 ，st. 班 号 ，sc. 课程 名 ，sc. 分 数 }; 
GridViewl. DataSource = myquery.ToList(); 
GridViewl. DataBind(); 


上 机 实验 题 14 


设计 步骤 如 下 : 
@ 打开 chl4 网 站 ,在 StudentDB 类 文件 中 添加 两 个 方法 : 


public DataSet SelectDatal( ) 


{ 


} 


string mystr; 
mystr = ConfigurationManager. ConnectionStrings["myconnstring"].ToString(); 
using (SqlConnection myconn = new SqlConnection()) 
{ myconn.ConnectionString = mystr; 
myconn. Open(); 
SqlCommand mycmd = new SqlCommand(); 
mycmd. CommandText = "SELECT * FROM student"; 
mycmd. Connection = myconn; 
using (SqlDataAdapter myda = new SqlDataAdapter()) 
{ myda.SelectCommand = mycmd; 
DataSet myds = new DataSet(); 
myda. Fill(myds, "student"); // 将 student 表 填 充 到 myds 中 
return myds; 


} 


public static void InsertData( string 学 号 ，string 姓名 ，string 性 别 ，string 民族 ,string 班 号 ) 


{ 


} 


string mystr, mysql; 

mystr = ConfigurationManager. ConnectionStrings["myconnstring"].ToString(); 

mysql = "INSERT INTO student( 学 号 ,姓名 ,性 别 , 民族 , 班 号 ) VALUES(@ 学 号 , @ 姓 名 , @ 人 性别, @ 
民族 , @ 班 号 )"; 

using (SqlConnection myconn = new SqlConnection(mystr)) 

using (SqlCommand mycmd = new SqlCommand(mysql, myconn)) 


{ mycmd.Parameters.Add("@ 姓 名 ", SqlDbType. VarChar,10).Value = 姓名 ; // 设 置 参 数值 
mycmd. Parameters. Add("@ 性 别 ", SqlDbType. VarChar, 2). Value= 性别; // 设 置 参 数值 
mycmd. Parameters. Add("@ 民 族 ", SqlDbType. VarChar,10).Value= 民族 ; // 设 置 参 数值 
mycmd. Parameters. Add("@ 班 号 ",SqlDbType. VarChar, 6). Value = 班 号 ; // 设 置 参 数值 
mycmd. Parameters. Add("@ 学 号 ", SqlDbType. VarChar, 5). Value = 学 号 ; // 设 置 参 数值 
myconn. Open(); 


mycmd. ExecuteNonQuery( ); 


@ 在 chl4 网 站 中 添加 一 个 Experment14 网 页 (采用 代码 隐藏 页 模型 ) 。 
@ 其 源 视图 代码 如 下 : 


<% @ Page Language= "C#" AutogventWireup= "true" CodeFile = "Experment14.aspx.cs" 


Inherits= "Experment14" %> 


<html xmlns = "http://www. w3.org/1999/xhtml" > 


<head runat = "server"> 
<title></title> 
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<style type= "text/css"> 
<! -一 省 略 若干 样式 定义 -一 > 
</style> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
<asp:ObjectDataSource ID = "ObjectDataSourcel”runat = "server" 
SelectMethod = " SelectData" TypeName = " StudentDB"” 
UpdateMethod = "UpdateData" InsertMethod = " InsertDatan> 
< InsertParameters > 
<asp:Parameter Name = "学 号 " TYpe= "String" /> 
<asp:Parameter Name = "姓名 " Type= "String" /> 
<asp:Parameter Name = "性 别 " Type= "String" /> 
<asp:Parameter Name = "民族 " Type= "String" /> 
<asp:Parameter Name = " 班 号 " Type= "String" /> 
</ InsertParameters> 
<UpdateParameters > 
<asp:Parameter Name = "学 号 " TYpe = "String" /> 
<asp:Parameter Name = "姓名 " Type= "String" /> 
<asp:Parameter Name = "性 别 " Type= "String" /> 
<asp:Parameter Name = "民族 " Type= "String" /> 
<asp:Parameter Name = " 班 号 " Type= "String" /> 
</UpdateParameters > 
</asp:ObjectDataSource > 
<table> 
<tr> 
<td style= "text ~ align: center" class = "auto- stylel"> 


所 有 学 生 记录 </td> 
<td style= "text ~ align: center" class = "auto- style2"> 
插入 单个 学 生 记录 </td> 
</tr> 
<tr> 


<td style = "width: 345px"> 
<asp:GridView ID = "GridView1”runat = "server" CellPadding = "4" 

DataSourceID = "ObjectDataSourcel”Font- Bold = "True" 

Font ~ Size = "Small" ForeColor = "#333333" GridLines = "None" 

OnPageIndexChanged = "GridViewl_PageIndexChanged" 

OnSelectedIndexChanged = "GridViewl_SelectedIndexChanged" 

AllowPaging = "True" PageSize = "4" 

Width = "343px" style = "font - family: 仿宋 "> 

<EditRowStyle BackColor = " 间 7C6F57" /> 

<FooterStyle BackColor = "#1C5E55" Font 一 Bold = "True" 
ForeColor = "White" /> 

<Columns> 
<asp:CommandF ield ShowSelectButton= "True" /> 

</Columns > 

<RowStyle BackColor = " #E3EAEB" /> 

<SelectedRowStyle BackColor = " 间 C5BBAF" ForeColor =" 井 333333" 
Font ~ Bold= "True" /> 

<PagerStyle BackColor = "#666666" ForeColor = "White" 
HorizontalAlign = "Center" /> 

<HeaderStyle BackColor = "#1C5E55" Font 一 Bold = "True" 
ForeColor = "White" /> 

<AlternatingRowStyle BackColor = "White" /> 
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< SortedAscendingCellStyle BackColor = " #F8FAFA" /> 
< SortedAscendingHeaderStyle BackColor = " 间 246B61" /> 
< SortedDescendingCellStyle BackColor = " #D4DFE1" /> 
< SortedDescendingHeaderStyle BackColor = "#15524A" /> 
</asp:GridView > 
</td> 
<td style= "width: 259px"> 
<asp:DetailsView ID = "DetailsViewl" runat = "server" 
AutoGenerateRows = "False" CellPadding = "4" 
DataSourceID = "ObjectDataSourcel" Font— Bold= "True" 
Font ~ Size = "Small" Height = "50px" 
Width = "218px" ForeColor = "#333333" GridLines = "None" 
style = "font - family: 楷体 "> 
<FooterStyle BackColor = "#1C5E55" ForeColor = "White" 
Font— Bold= "True" /> 
<EditRowStyle BackColor = " 间 7C6F57" /> 
<RowStyle BackColor = " #E3EAEB" /> 
<PagerStyle ForeColor = "White" HorizontalAlign= "Center" 
BackColor = " 间 666666" /> 
<Fields> 
<asp:BoundField DataField= "学 号 ”HeaderText = "学 号 " > 
<ControlStyle Width = "40px" /> 
</asp:BoundField> 
<asp:BoundField DataField= "姓名 ”HeaderText = "姓名 "> 
<ControlStyle Width = "60px" /> 
</asp:BoundField> 
<asp:BoundField DataField= "性 别 " HeaderText = "性 别 " > 
<ControlStyle Width = "40px" /> 
</asp:BoundField> 
<asp:BoundField DataField= "民族 "HeaderText = "民族 " > 
<ControlStyle Width = "70px" /> 
</asp:BoundField> 
<asp:BoundField DataField= " 班 号 " HeaderText = " 班 号 " > 
<ControlStyle Width = "60px" /> 
</asp:BoundField> 
<asp:CommandF ield ShowInsertButton= "True" /> 
</Fields> 
< HeaderStyle BackColor = "#1C5E55" Font ~ Bold = "True" ForeColor = "White" /> 
< CommandRowStyle BackColor = " # C5BBAF" ForeColor = "red" Font - Bold = "True" /> 
<FieldHeaderStyle BackColor = "#5DODODO" Font ~ Bold= "True" /> 
<AlternatingRowStyle BackColor = "White" /> 
</asp:DetailsView > 
</td> 
</tr> 
</table> 
</div> 
</form> 
</body> 
</html > 


@ 本 网 页 的 事件 处 理 过 程 如 下 : 


Pprotected void GridViewl_SelectedIndexChanged( object sender, EventArgs e) 
{ DetailsView1.ChangeMode(DetailsViewMode. ReadOnly); 
DetailsViewl. PageIndex = GridView1.PageIndex * GridView1.PageSize 
+ GridViewl.SelectedIndex; 
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} 
protected void GridViewl_ PageIndexChanged(object sender, EventArgs e) 
{ DetailsViewl.ChangeMode(DetailsViewMode. ReadOnly); 
DetailsViewl. PageIndex = GridView1.PageIndex * GridViewl.PageSize; 


上 机 实验 题 15 


设计 步骤 如 下 : 
QO@ 打开 Web 网 站 ,在 WebServicel. cs 文件 中 添加 一 个 名 称 为 compavg 的 Web 服务 ,其 
代码 如 下 : 


[WebMethod] 
public string compavg(string kcm) 
{ string mystr, mysql, retstr; 
mystr = System. Configuration.ConfigurationManager. 
ConnectionStrings[ "myconnstring" ]. ToString(); 
SqlConnection myconn = new SqlConnection(); 
myconn. ConnectionString = mystr; 
myconn. Open( ); 
SqlCommand mycmd = new SqlCommand(); 
mysql = "SELECT AVG( 分 数 ) FROM score WHERE 课程 名 = " + kcm + " 
mycmd. CommandText = mysql; 
mycmd. Connection = myconn; 
retstr = mycmd. ExecuteScalar().ToString(); 
myconn. Close( ); 
return retstr; 


} 
@ 打开 ch15 网 站 ,在 其 中 添加 一 个 Experment15 网 页 (采用 代码 隐藏 页 模型 ) 。 
@ 其 源 视图 代码 如 下 : 


<% @ Page Language = "C#" AutoEventWireup= "true" CodeFile = "Experment15. aspx. cs" 
Inherits = "Experment15" %> 
<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
< head runat = "server"> 
<meta http - equiv= "Content ~ Type" content = "text/html; charset =utf— 8"/> 
<title></title> 
<style type= "text/css"> 
.auto— stylel { 
font - family: 楷体 ; font - weight: bold; 
font - size: medium; color: 间 #0000FF; 


} 
</style> 
</head> 
<body> 
<form id= "forml" runat = "server"> 
<div> 
< span class = "auto - stylel"> 课 程 名 : </span> 
<asp:DropDownList ID = "DropDownList1" runat = "server" style= "color: 间 #0000FF; 
font - size: medium; font— weight: 700; font- family: 仿宋 "> 
<asp:ListItem>C 语 言 </asp:ListItem> 
<asp:ListItem> 数 据 结构 </asp:ListItem> 
</asp:DropDownList > 


521 
附录 A 上 机 实验 题 设 计 参 考 答 


<asp:Button ID = "Button1”runat = "server" OnClick = "Button1_Click" 
style = "color: 井 FF0000; font - size: medium; font - weight: 700; 
font - family: 黑体 " Text = " 求 平 均 分 " /> 

<br /><br /> 


<br /><br /> 


<asp:Label ID= "Label1" runat = "server" style = "color: #FFOOFF; 


font - size: medium; font — weight: 700; font — family: 仿宋 "></asp:Label> 
<br /> 


</div> 
</form> 
</body> 
</html > 


@ 本 网 页 的 事件 处 理 过 程 如 下 : 


protected void Button1_Click(object sender, EventArgs e) 

{ localhost. WebServicel myservice = new localhost. WebServicel(); 
if (DropDownList1.SelectedValuel= "") 
{ ”Labell.Text = "平均 分 :" + 


myservice. compavg( DropDownList1. SelectedValue. ToString( )); 
} 


上 机 实验 题 16 
Web. config 文件 的 配置 如 下 : 


< system. web> 
<authentication mode = "Forms"> 
<forms loginUrl = "logon.aspx" name = ". ASPXFORMSAUTH" /> 
</authentication > 
<authorization > 
<deny users = "?" /> 
</authorization > 
</system. web> 


上 机 实验 题 17 


设计 步骤 如 下 : 
Q@ 打开 ch17 网 站 ,添加 一 个 名 称 为 Experment17. aspx 的 网 页 。 
@ 在 网 页 中 添加 一 个 ChangePassword 控件 ,通过 “Login 任务 ”中 的 “自动 套用 格式 ” 设 


置 其 方案 为 "传统 型 ”, 并 将 其 DisplayUserName 属性 设置 为 True( 显 示 用 户 名 ) ,不 设计 任何 
事件 过 程 。 其 源 视 图 代码 如 下 : 


<% @ Page Language = "C#" AutoEventWireup = "true" CodeFile = "Experment17. aspx.cs" 
Inherits = "Experment17" $%> 
<!DOCTYPE html > 
<html xmlns = "http://www.w3.org/1999/xhtml"> 
<head runat = " server"> 
<meta http - equiv= "Content ~ Type" content = "text/htm1; charset = utf— 8"/> 
<title ></title> 
</head> 
<body> 


<form id= "forml" runat = "server"> 
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<div> 
<asp:ChangePassword ID = "ChangePassword1" runat = "server" BackColor = " # EFF3FB" 
BorderColor = " 井 B5C7DE”BorderPadding = "4" BorderStyle = "Solid" 
BorderWidth = "lpx" DisplayUserName= "True" Font— Names = "Verdana" 
Font ~ Size = "0. 8em"> 
< CancelButtonStyle BackColor = "White" BorderColor = "#507CD1" 
BorderStyle = "Solid" BorderWidth = "1lpx" Font— Names = "Verdana" 
Font — Size = "0. 8em" ForeColor = "#284F98" /> 
< ChangePasswordButtonStyle BackColor = "White" BorderColor = "#507CD1" 
BorderStyle = "Solid" BorderWidth = "1lpx" Font— Names = "Verdana" 
Font ~ Size = "0. 8em" ForeColor = "#284FE98" /> 
< ContinueButtonStyle BackColor = "White" BorderColor 井 507CD1" 
BorderStyle = "Solid" BorderWidth = "lpx" Font— Names = "Verdana" 
Font- Size = "0. 8em" ForeColor = "#284F98" /> 
< InstructionTextStyle Font - Italic = "True" ForeColor = "Black" /> 
<PasswordHintStyle Font - Italic= "True" ForeColor =" 间 #507CD1" /> 
< TextBoxStyle Font - Size= "0. 8em" /> 
<TitleTextStyle BackColor = "#507CD1" Font ~ Bold= "True" Font - Size = "0.9em" 
ForeColor = "White" /> 
</asp:ChangePassword> 
</div> 
</form> 
</body > 
</html > 


上 机 实验 题 18 


学 生 端 功 能 设计 参见 学 生成 绩 管理 网 站 的 Student 目录 的 相关 网 页 文件 ,教师 端 功能 设 
计 参 见 学 生成 绩 管理 网 站 的 Teacher 目录 的 相关 网 页 文件 。 


APPENDIX B 


综合 上 机 实验 题 附录 B 


采用 ASP.NET 十 SQL Server 十 C# 实 现 如 下 系统 。 

1. 图 书 管理 系统 

模拟 大 学 的 图 书 管理 系统 ,包括 图 书信 库 .读者 (学 生 和 教师 ) 信 息 输入 与 
编辑 .读者 借 书 .读者 还 书 等 功能 。 

2. 网 上 图 书 销售 管理 系统 

模拟 当当 网 站 的 图 书 销售 部 分 的 功能 ,包括 图 书信 息 上 传 . 读 者 浏览 图 书 、 
读者 注册 与 登录 .读者 购买 图 书 ,注册 读者 的 订单 管理 等 。 

3. 网 上 商品 销售 管理 系统 

模拟 当当 网 站 的 其 他 商品 销售 部 分 的 功能 ,包括 商品 信息 上 传 、 客 户 浏览 
商品 、 客 户 注册 与 登录 客户 购买 商品 .注册 客 户 的 订单 管理 等 。 

4. 网 上 商城 管理 系统 

模拟 淘宝 网 站 的 部 分 功能 ,包括 卖家 和 买 家 的 管理 。 

5. 网 上 论坛 管理 系统 

模拟 课程 学 习 论 坛 的 功能 ,包括 用 户 注册 与 登录 、 用 户 发 帖 \ 用 户 回 帖 等 
功能 。 

6. 聊天 室 管理 系统 

实现 群 聊 、 私 聊 、 显 示 在 线 用 户 等 功能 。 


APPENDIZX C&C 


附录 C 使 用 学 生成 绩 管理 系统 


使 用 学 生成 绩 管理 系统 的 操作 步骤 如 下 。 

a 环境 准备 : 在 计算 机 上 安装 好 Visual Studio 2012( 或 更 高 版 本 ) 和 SQL 
Server 2012 下 xpress。 

@ 将 本 书 的 源 代码 复制 到 自己 的 计算 机 上 ,如 文件 夹 是 “D:\ASP.NET”。 

@ 进入 “学 生成 绩 管理 系统 ”文件 夹 的 App_Data 子 文件 夹 , 右 击 StudDB 
文件 ,在 出 现 的 快捷 菜单 中 选择 “属性 ”命令 ,然后 选择 “安全 "选项 卡 , 单 击 “ 编 
辑 ? 按 钮 ,出 现 *“StudDB 的 权限 ”对 话 框 ,在 “组 或 用 户 名 ”列表 中 单 击 自己 的 用 
户 名 ,如 “User(LCB-PC\ Users)”, 勾 选 “Users 的 权限 ”列表 中 的 所 有 允许 项 ， 
如 图 C. 1 所 示 。 


ET 
安全 
对 象 名 称 。 6: WASP. 亚 IT 动态 网 站 设计 教程 -正式 版 "学 习 资 


组 或 用 户 名 (6); 
中 huthenticated Users 
号 srsSTEN 


Administrators (LLB-PC\Administrators) 
中 Users (LCB-PC\Users) 


Vsers 的 权限 ) 允许 


图 C.1 “StudDB 的 权限 ”对 话 框 


@ 对 StudDB_log 文件 做 同样 的 授权 。 

@ 启动 SQL Server 2012 Express， wl 
结 点 ,在 出 现 的 快捷 菜单 中 选择 “附加 ”命令 ,如 图 C 
所 示 。 

@ 出 现 “ 附 加 数据 库 ” 对 话 框 , 单 击 “ 添 加 ”按钮 , 选 
择 “D:\ASP.NET\ 学 生成 绩 管理 系统 \App_Data” 文 件 
夹 中 的 StudDB 文件 ,如 图 C. 3 所 示 , 单 击 “ 确 定 ” 按 钮 ， 
这 样 就 在 本 机 上 创建 了 StudDB 数据 库 。 

@ 启动 Visual Studio 2012, 选 择 “ 文 件 | 打开 | 网 
tb nd 

学 生成 绩 管理 系统 ”, 单 击 “ 打 开 ” 按 钮 ,这 样 就 进入 了 
学 生成 绩 管理 系统 网 站 ,打开 Default. aspx 网 页 即 可 运 
行 该 系统 。 


昌 册 本 * 四 必 助 


附录 C 使 用 学 生成 绩 管 理 系 


日 发 LcB-PC\SQLEXPRESS (SQL Server 11.0.2100 - sa) 


要 附加 的 救 据 库 0) 
中 MDF 文 件 位 置 


数据 庄 
| D: MASP. 亚 T\ 学 生成 绩 管 理 系统 . 本 StudDB 


服务 器 ; 
LCEB-PC\SQLEXPRESS 
连接 

sa 


村? 查 在 连接 攻 性 


_ 文件 类 型 。 当前 文件 路 径 
数据 JD: AASP.RET\ 学 生成 . 
| stuaDB_los 14f 日志 DT: AASP. NET\ 学 生成 


[inE 录 ©... ] 给 m |] 


图 C.3 “附加 数据 库 ? 对 话 框 


注意 : 本 书 使 用 SQL Server 数据 库 管 理 系统 的 sa 登录 账号 的 密码 为 12345, 服 务 器 名 称 
为 LCB-PC\SQLEXPRESS, 如果 使 用 其 他 服务 器 名 称 或 密码 ,可 以 相应 修改 示例 网 站 中 的 连 


接 字符 囊 。 


说 明 : 从 第 12 章 开 始 使 用 Stud 数据 库 , 该 数据 库 文件 存放 在 “\ch1l2\App_Data” 文 件 夹 
中 ,在 SQL Server 2012 Express 中 附加 Stud 数据 库 的 方法 与 上 述 相 同 。 
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